Laravel框架路由和控制器的绑定操作方法
本文实例讲述了Laravel框架路由和控制器的绑定操作方法。分享给大家供大家参考,具体如下:
路由和控制器的关系
路由文件地址在\app\Http\routes.php,我们来看两种不同的路由。
Route::get('/', function () { return view('welcome'); }); Route::get('/hi', function () { return 'hello world'; });
以上均为绑定匿名函数的路由,虽然可以返回视图,也可以返回字符串,但本质都是一样的。
Route::get('/blog','BlogController@index'); Route::get('/post/{slug}','BlogController@showPost');
这两种是绑定控制器的路由,控制器类BlogController下有两个函数,index和showPost,可以调用。
那么问题来了,究竟应该选用哪种?
你不可能把复杂的业务逻辑都写在一个匿名函数里,所以你要学会新建控制器。
Route::get('/mvc', 'MyController@hello');
添加新控制器
控制器文件夹地址在Laravel文件夹下\app\Http\Controllers,我们继续使用artisan控制台创建一个新控制器
php artisan make:controller MyController
然后,回到控制器目录,一份新的MyController.php文件被创建了,代码如下:
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use App\Http\Requests; class MyController extends Controller { // }
我们修改MyController类,同时再创建一个视图。
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use App\Http\Requests; class MyController extends Controller { public function hello() { return View('myview'); } }
如果这么写,就意味着一旦用户访问URL:laravel/public/mvc,路由就会交给MyController控制器的hello函数,hello函数返回myview视图,即返回myview.blade.php
我们看看myview.blade.php的代码
@extends('layouts.app') @section('content') <div class="container"> <div class="row"> <div class="col-md-10 col-md-offset-1"> <div class="panel panel-default"> <div class="panel-heading">{{ $d1 }}</div> <div class="panel-body"> this is my view! </div> </div> </div> </div> </div> @endsection
这里的{{ $d1 }}
希望用一个变量的值来代替,所以,我们把MyController控制器修改为
class MyController extends Controller { public function hello() { return View('myview',['d1'=>'a1']); } }
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》及《》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。