zoukankan      html  css  js  c++  java
  • Laravel路由和控制器的绑定

    路由和控制器的关系

    路由文件地址在appHttp outes.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文件夹下appHttpControllers,我们继续使用artisan控制台创建一个新控制器

    php artisan make:controller MyController
    

    然后,回到控制器目录,一份新的MyController.php文件被创建了,代码如下:

    <?php
    
    namespace AppHttpControllers;
    
    use IlluminateHttpRequest;
    
    use AppHttpRequests;
    
    class MyController extends Controller
    {
        //
    }
    

    我们修改MyController类,同时再创建一个视图。

    <?php
    
    namespace AppHttpControllers;
    
    use IlluminateHttpRequest;
    
    use AppHttpRequests;
    
    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']);
    	}
    }
    

      

    本文为博主原创文章,转载请在明显位置注明出处: http://www.cnblogs.com/sweng

    本作品采用知识共享署名-非商业性使用-禁止演绎 3.0 未本地化版本许可协议进行许可。

  • 相关阅读:
    IDEA 如何批量修改变量名
    Idea 竖选文本、竖向选择、横向纵向选择文本代码
    IDEA中的.iml文件和.idea文件夹
    IDEA-Maven的Dependencies中出现红色波浪线
    接收来自路劲中的参数
    Jquery基础知识点
    JavaScript浏览器对象
    JavaScript面向对象编程
    HTML5 <iframe> 标签
    JavaScript标准对象
  • 原文地址:https://www.cnblogs.com/sweng/p/6340515.html
Copyright © 2011-2022 走看看