


Teilen Sie Ihre persönlichen empfohlenen Programmierspezifikationen für Laravel oder andere Frameworks
die Programmierspezifikationen von Laravel oder anderen von Ihnen empfohlenen Frameworks vorgestellt. Ich hoffe, dass sie Freunden in Not hilfreich sein werden! Vorläufige Zusammenfassung
Während der Entwicklung neigen viele Schüler zu Verwirrung, Zufälligkeit und mangelnder Einheitlichkeit bei der Dateibenennung. Diese Situation ist besonders ausgeprägt, wenn mehrere Personen zusammenarbeiten. Jeder Entwickler muss sich an die Entwicklungsgewohnheiten aller anpassen. Viele Unannehmlichkeiten behindern die Effizienz der kollaborativen Entwicklung mehrerer Personen.
Einheitliche SpezifikationenDie Verwendung einheitlicher Entwicklungsspezifikationen hat viele Vorteile. Eine davon besteht darin, die Reibung zwischen Entwicklern zu verringern. Zum Beispiel:
app/Models/User.php
···/**
* @desc 获取 users.username
* @param int $user_id users.id
* @return string
*/public static function getUsername(int $user_id): string{
return self::where('id', $user_id)->value('username');}// getUsername() end/**
* @desc 获取 users.age
* @param int $user_id users.id
* @return int
*/public static function getAge(int $user_id): int{
return (int)self::where('id', $user_id)->value('age');}// getAge() end···
Nach dem Login kopieren
In den Kommentaren des Zeilenparameters $user_id
verwende ich users.id Formular. Dieses Formular ist meine Hauptempfehlung. Der Vorteil besteht darin, dass Sie den Ursprung dieses Parameters (das Feld <code>id
in der Tabelle users
) intuitiv erkennen können. Die zurückgegebenen Parameter werden ebenfalls intuitiv erklärt und der Wert ist der Wert des Felds username
in der Tabelle users
.
···/** * @desc 获取 users.username * @param int $user_id users.id * @return string */public static function getUsername(int $user_id): string{ return self::where('id', $user_id)->value('username');}// getUsername() end/** * @desc 获取 users.age * @param int $user_id users.id * @return int */public static function getAge(int $user_id): int{ return (int)self::where('id', $user_id)->value('age');}// getAge() end···
Funktion
-Benennung unterscheidet sich durch Aktion, get + field
übernimmt den Wert und set + field
aktualisiert den Wert. Einheitliche Benennung$user_id
的注释里,我使用的是 users.id
的形式。此形式是我主推的,优点是直观的知道此参数的由来(users
表中 id
字段)。
返回的参数也做了直观的说明,取值为 users
表中 username
字段的值。function
命名按照动作来区分命名,get + 字段
取值,set + 字段
更新值。
命名统一
下面,我通过 users
users
als Beispiel, um die von mir empfohlene Benennungslogik aufzulisten. Tabelle – Benutzer nutzt die Benutzertabelle als Blaupause, um diesen Standard bei Schülern bekannt zu machen.
migrations – Datenbankmigrationen database/migrations/xxxx_create_users_table.php
···use Illuminate\Support\Facades\DB;··· Schema::create('balance_logs', function (Blueprint $table) {
$table->id();
$table->string('username', 32)->unique()->nullable(false)->comment('名称');
$table->string('password', 128)->nullable(false)->comment('密码');
$table->unsignedInteger('age', 3)->default(0)->comment('年龄');
$table->string('token', 128)->nullable(true)->comment('登录态');
$table->dateTime('created_at')->useCurrent();
$table->dateTime('updated_at')->useCurrent();
$table->index('username', 'username_index');
});
DB::statement("ALTER TABLE `users` comment '用户表'");···
Nach dem Login kopieren
model – Modell app/Models/User.php ···use Illuminate\Support\Facades\DB;··· Schema::create('balance_logs', function (Blueprint $table) { $table->id(); $table->string('username', 32)->unique()->nullable(false)->comment('名称'); $table->string('password', 128)->nullable(false)->comment('密码'); $table->unsignedInteger('age', 3)->default(0)->comment('年龄'); $table->string('token', 128)->nullable(true)->comment('登录态'); $table->dateTime('created_at')->useCurrent(); $table->dateTime('updated_at')->useCurrent(); $table->index('username', 'username_index'); }); DB::statement("ALTER TABLE `users` comment '用户表'");···
controller – Controller. app/ Http/Controllers/ UserController .php
App /Events/UserEvent.php event
app/Listeners/UserListener.php listenerconsole – Aufgabenplanung
app/Console/Commands/UserCommand.php
<?phpnamespace App\Http\Controllers\Api\v1;use App\Http\Controllers\Controller;use Illuminate\Http\Request;use App\Models\User;class UserController extends Controller{ public function index(Request $request) { // todo }// index() end public function show(Request $request) { // 变量命名,对应的是表字段的话,变量名建议以该字段为名, // 注释时采用 表名.字段 的形式 // users.username $username = $request->post('username'); }// show() end public function store(Request $request) { $user_id = $request->post('user_id');// users.id $age = $request->post('age'); // users.age // 更新数据 User::where('id', $user_id)->update(['age' => $age]); }// store() end}
seeder – Datenfüllung
- Datenbank /seeds/UserSeeder.php generiert gefälschte Daten
- database/factories/UserFactory.php Modellfabrik
Spezifikationsdefinition
Ich definiere die obige Spezifikation als
benannt mit Tabellenspezifikation, dafür Die Erklärung ist das mit Tabellenname als Hauptzeile, Dokumente, die das zugehörige Geschäft festlegen, werden mit
Tabellenname- als Schlüsselwort benannt.
- Naming - Mind Map
FazitIch hoffe, dass meine persönlichen Vorschläge umgesetzt werden können und bei den Studierenden Anklang finden. Vielen Dank an die Studierenden fürs Lesen. Denken Sie bitte daran, „Gefällt mir“, „Kommentar“, „Sammeln“ und „Retweeten“ zu markieren.
Das obige ist der detaillierte Inhalt vonTeilen Sie Ihre persönlichen empfohlenen Programmierspezifikationen für Laravel oder andere Frameworks. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.

Vergleichen Sie Laravel's Blade und die Twig-Vorlagen-Engine von CodeIgniter und wählen Sie je nach Projektanforderungen und persönlichen Vorlieben: Blade basiert auf der MVC-Syntax, die eine gute Codeorganisation und Vorlagenvererbung fördert. Twig ist eine Bibliothek eines Drittanbieters, die flexible Syntax, leistungsstarke Filter, erweiterten Support und eine Sicherheits-Sandbox bietet.

Laravel – Paginierungsanpassungen – Laravel enthält eine Paginierungsfunktion, die einem Benutzer oder Entwickler hilft, eine Paginierungsfunktion einzubinden. Der Laravel-Paginator ist in den Abfrage-Builder und Eloquent ORM integriert. Die Paginierungsmethode automatisch
