php artisan make:controller UserController --plain
只要后面跟个plain标识符 就可以生成空的控制器啦。
1.2.2 单条路由使用控制器
上面是使用resource方法来对应控制器的动作了,像这种空的控制器咱怎么在路由中使用呢?
/** * 控制器名@方法名 就可以了 */ Route::get('/user', 'UserController@index'); /** * 这是在配置一些其他东西时的写法,因为要在数组中嘛,它对应的KEY是uses。 */ Route::get('/user', ['as' => 'showUser', 'uses' => 'UserController@index']);
然后自行实现UserController的index方法就可以咯:
class UserController extends Controller { public function index() { return '展示一些东西'; } }
1.3.1 其实还有另一种写法 隐式控制器
这种路由我不太常用 先来看看语法吧:
Route::controller('/user', 'UserController');
首先 使用了controller来注册路由,第一个参数是路径没新鲜的,第二个参数是控制器 但是它没有跟着方法。因为它能自动根据路径相应到方法 看看下面控制器方法的实现。
class UserController extends Controller { /** * 对应着 /user/ 路由 GET方式 */ public function getIndex() { return '展示一些东西~'; } /** * 对应着 /user/show/{id} 路由 GET方式 */ public function getShow($id) { return '此用户ID为: '.$id; } /** * 对应着 /user/update/{id} 路由 POST方式 */ public function postUpdate($id, Requests\Request $request){ } }
这个控制器的方法开头都是HTTP请求的方式 最常用的就是GET 和 POST 后面跟的是方法名字,具体对应的路径在注释中写清楚了。
如果你想给这些路由命名的话,后面可以跟一个数组来命名:
Route::controller('/user', 'UserController',['getShow' => 'user.show']);
这样就可以给对应的方法命名了,oh funk 大K真的不喜欢这种方式,也许是没明白这样写的真谛把。
--今天关于控制器就先写这么多吧,具体逻辑实现咱还得学一些新的知识来结合使用,比如middleware啊和request还有blade模板引擎,但都不是很难~
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。