🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
5.1 命令行很适合编写一些自定义命令了,例如上节权限管理里面编写的发布文件的一些命令。你还可以编写脚本命令来实现业务上的一些东西。平常我们经常用到的一些 CURD 文件,所以为了后期方便的,这里快速就编写一个命令行,此后 curd 基础文件都使用该命令创建。 ## 如何创建 首先要做一些基础工作,肯定需要的是一些 CURD 模板文件,然后在此基础利用命令行创建。 ![](https://box.kancloud.cn/029f92f7be8f5719dcdeeaa4dd57aaf1_306x189.png) 依据文档需要在 application 创建 command目录,然后在创建一个命令文件 CurdMaker.php。然后还有 **stub** 目录, 这里存放的是模板文件,是之后创建 CURD 的基础。 Stub 三个文件如下, 具体根据自己的喜好定义。 ### controller.stub ``` <?php namespace app\$module\controller; use think\Controller class $controller extends Controller { public function index() { return $this->fetch(); } public function create() { return $this->fetch(); } public function edit() { return $this->fetch(); } public function delete() {} } ``` ### model.stub ``` <?php namespace app\$module\model; use think\Model; class $model extends Model { public function getAll() {} public function findBy() {} public function updateBy() { } public function deleteBy() {} } ``` view.stub 目前还没有任何内容,后期会补上,为什么会没有呢,因为后台管理的模板的样式肯定具有一定性共通特征。这里可以利用 view 继承的特性可以进行管理,所以这里此后添加。 最后在 application 目录下的 command.php 添加命令行 ``` 'make:curd' => app\command\CurdMaker::class, ``` ### 编写命令 命令一共需要三个参数,[controller, model, module?], module是可选的,如果没有的话会自动获取 app.php 配的默认模块名称。下面直接上代码。在代码里面进行一定量的解释。可能有点枯燥,如果有不好的地方的也可以提供评论指出,我会进行修改 ``` namespace app\command; use think\console\Command; use think\console\Input; use think\console\input\Argument; use think\console\input\Option; use think\console\Output; class CurdMaker extends Command { protected $appPath; // view 默认的三个模板 protected $views = ['index', 'create', 'edit']; public function __construct() { parent::__construct(); $this->appPath = env('app_path'); } protected function configure() { $this->setName('make:curd') ->addArgument('controller', Argument::OPTIONAL, "controller name") ->addArgument('model', Argument::OPTIONAL, "model name") ->addOption('module', null, Option::VALUE_REQUIRED, 'module name') ->setDescription('Create curd option controller model --module?'); } protected function execute(Input $input, Output $output) { // 首先获取默认模块 $moduleName = config('app.default_module'); $controllerName = trim($input->getArgument('controller')); if (!$controllerName) { $output->writeln('Controller Name Must Set');exit; } $modelName = trim($input->getArgument('model')); if (!$modelName) { $output->writeln('Model Name Must Set');exit; } if ($input->hasOption('module')) { $moduleName = $input->getOption('module'); } $this->makeController($controllerName, $moduleName); $output->writeln($controllerName . ' controller create success'); $this->makeModel($modelName, $moduleName); $output->writeln($modelName . ' model create success'); $this->makeView($controllerName, $moduleName); $output->writeln($controllerName . 'view create success'); } // 创建控制器文件 protected function makeController($controllerName, $moduleName) { $controllerStub = $this->appPath . 'command' . DIRECTORY_SEPARATOR . 'stub' .DIRECTORY_SEPARATOR. 'Controller.stub'; $controllerStub = str_replace(['$controller', '$module'], [ucfirst($controllerName), strtolower($moduleName)], file_get_contents($controllerStub)); $controllerPath = $this->appPath . $moduleName . DIRECTORY_SEPARATOR . 'controller' . DIRECTORY_SEPARATOR; if (!is_dir($controllerPath)) { mkdir($controllerPath, 0777, true); } return file_put_contents( $controllerPath . $controllerName . '.php', $controllerStub); } // 创建模型文件 public function makeModel($modelName, $moduleName) { $modelStub = $this->appPath . 'command' . DIRECTORY_SEPARATOR . 'stub' .DIRECTORY_SEPARATOR. 'Model.stub'; $modelPath = $this->appPath . $moduleName . DIRECTORY_SEPARATOR . 'model'; if (!is_dir($modelPath)) { mkdir($modelPath, 0777, true); } $modelStub = str_replace(['$model', '$module'], [ucfirst($modelName), strtolower($moduleName)], file_get_contents($modelStub)); return file_put_contents($modelPath . DIRECTORY_SEPARATOR . $modelName . '.php', $modelStub); } // 创建模板 public function makeView($controllerName, $moduleName) { $viewStub = $this->appPath . 'command' . DIRECTORY_SEPARATOR . 'stub' .DIRECTORY_SEPARATOR. 'View.stub'; $viewPath = (config('template.view_path') ? config('template.view_path') . $moduleName . DIRECTORY_SEPARATOR : env('app_path') . $moduleName . DIRECTORY_SEPARATOR . 'view' . DIRECTORY_SEPARATOR) . strtolower($controllerName); if (!is_dir($viewPath)) { mkdir($viewPath, 0777, true); } foreach ($this->views as $view) { file_put_contents($viewPath . DIRECTORY_SEPARATOR . $view .'.html', file_get_contents($viewStub)); } } } ``` 这样一个 CURD 命令行就已经创建好了, 来使用了看看。 ## 使用 ``` php think 查看一下命令是够存在 ``` ![](https://box.kancloud.cn/c2a05c33c6c9315430b2179d6584cec1_599x192.png) 一已经有了,来尝试创建一下。首先使用默认的模块 index ``` php think make:curd Chat Chat ``` ![](https://box.kancloud.cn/3e90ee5a99d2c48656ad2dba7bbdf4ac_499x142.png) ![](https://box.kancloud.cn/d165c57bd1c237ca79f3bd8fcc394684_272x195.png) 没问题,创建成功了。 一已经有了,再来创建使用新的模块 admin, 使用模块的话,就必须如下使用了 ``` php think make:curd Chat Chat --module admin ``` ![](https://box.kancloud.cn/632983ffe797a64cf852ed9b42808e25_573x135.png) ![](https://box.kancloud.cn/fc013d496eb4839d885e5f9e33978e3d_301x175.png) 嗯,已经没有问题了,可以正常使用了,以上就是编写 CURD 命令的过程。