首頁 > php框架 > Laravel > 分享個人推薦的laravel或其它框架的程式規範

分享個人推薦的laravel或其它框架的程式規範

藏色散人
發布: 2021-02-09 09:10:59
轉載
2123 人瀏覽過

前情提要在開發的時候,許多同學在

檔案命名

方面,容易出現絮亂,隨意性強,沒有統一性。此種情況,在多人協同時,尤為突出。各開發人員都要去適應每個人的開發習慣,諸多不便,阻礙了多人協同開發的效率。

統一規範使用統一的開發規範,好處很多。減少開發間的磨合,是其一,舉例:

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···
登入後複製
在行參$user_id

的註解裡,我使用的是

users.id
的形式。此形式是我主推的,優點是直覺的知道此參數的由來(

users

表中 id 欄位)。 傳回的參數也做了直覺的說明,取值為 users 表中 username 欄位的值。
function 命名依照動作來區分命名,get 欄位 取值,set 欄位
更新值。 命名統一下面,我透過

users

表舉例,列舉我推薦命名的邏輯。

table - users以 users 表來當藍本,向同學推行此規格。

migrations - 資料庫遷移

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 '用户表'");···
登入後複製

#model - 模型

app/Models/User.php

controller - 控制器

app/Http/Controllers/UserController.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}
登入後複製

#request - 表單驗證

app/Http/Requests/UserRequest.php

observer - 觀察者

app/Observers/UserObserver.php

event - 事件系統

app/Events/UserEvent.php 事件

app/Listeners/UserListener.php 監聽器

  • console - 任務排程
  • app/Console/Commands/UserCommand.php
$ php artisan my:user
登入後複製

##seeder - 資料填入

database/seeds/UserSeeder.php 產生假資料

database/factories/UserFactory.php 模型工廠

  • 規格定義
  • 我將上面此種規範定義為
  • 以表規名
,對此的解釋是,以

表名為主線,規定其相關業務的文件,均以表名

為關鍵字進行後續文件的命名。

命名- 心智圖

結語

希望我的個人建議,能在同學間推行與流行。謝謝同學們的閱讀,記得幫我 分享個人推薦的laravel或其它框架的程式規範按讚

評論收藏

轉發

以上是分享個人推薦的laravel或其它框架的程式規範的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:learnku.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板