Laravel最佳分割路由文件(routes.php)的方式

前言

Laravel 的路由功能很强大,默认都是定义在 routes.php 文件中,随着项目越来越大,我们需要的定义的路由越来越多,想象一下,如果几百上千个路由都定义在一个文件中,如何去维护?也许还有不同的人都在同一个文件定义路由,这就造成了冲突,因此我们需要分割 routes.php 文件。

下面介绍一种很优雅的方式。

app/Providers/RouteServiceProvider.php map 方法中可以如下定义:

public function map(Router $router)
{
  $router->group(['namespace' => $this->namespace], function ($router) {
    //require app_path('Http/routes.php');
    foreach (glob(app_path('Http//Routes') . '/*.php') as $file) {
      $this->app->make('App\\Http\\Routes\\' . basename($file, '.php'))
->map($router);
    }
  });
}

文件组织结构图如下:

这样它会遍历 app/Http/Routes/ 文件夹下的文件,遍历每个文件路由类的 map 方法,每个文件的结构都类似,

举个例子:

<?php
/**
 * Created by PhpStorm.
 * User: xl
 * Date: 2016/7/4
 * Time: 18:07
 */
namespace App\Http\Routes;

use Illuminate\Contracts\Routing\Registrar;

class HomeRoutes
{
  public function map(Registrar $router)
  {
    $router->group(['domain' => 'www.tanteng.me', 'middleware' => 'web'], 
function ($router) {
      $router->auth();
      $router->get('/', ['as' => 'home', 'uses' => 'IndexController@index']);
      $router->get('/blog', ['as' => 'index.blog', 'uses' => 
'BlogController@index']);
      $router->get('/resume', ['as' => 'index.resume', 'uses' => 
'IndexController@resume']);
      $router->get('/post', ['name' => 'post.show', 'uses' => 
'ArticleController@show']);
      $router->get('/contact', ['as' => 'index.contact', 'uses' =>
 'IndexController@contact']);
      $router->post('/contact/comment', ['uses' => 
'IndexController@postComment']);
      $router->get('/travel', ['as' => 'index.travel', 'uses' => 
'TravelController@index']);
      $router->get('/travel/latest', ['as' => 'travel.latest', 
'uses' => 'TravelController@latest']);
      $router->get('/travel/{destination}/list', ['as' =>
 'travel.destination', 'uses' => 'TravelController@travelList']);
      $router->get('/travel/{slug}', ['uses' => 
'TravelController@travelDetail']);
      $router->get('/sitemap.xml', ['as' => 'index.sitemap', 'uses'
 => 'IndexController@sitemap']);
    });
  }
}

把路由规则都写到每个文件的 map 方法中,这样一来,就实现了很好的 routes.php 文件的分开管理。此外,你也可以简单的分割,直接把 routes.php 中的定义拆散成多个文件,通过 require 的方式引入,但是哪个更好,一目了然。

那么这样路由分开多个文件后岂不是增加调用次数,会不会影响性能?答案是不必担心。通过 Laravel 的命令:

php artisan route:cache
生成路由缓存文件后,路由只会读取缓存文件的路由规则,因此不会影响性能,这样做让开发更高效和规范。
`routes.IgnoreRoute`、`routes.MapPageRoute`和`routes.MapRoute`是在ASP.NET中用于定义和配置路由规则的方法。它们之间的区别如下: 1. `routes.IgnoreRoute`:这个方法用于忽略某些URL,让它们不被路由系统处理。通常用于忽略某些特定的静态文件或资源,如图片、CSS文件、JavaScript文件等。示例用法如下: ```csharp routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); ``` 上述示例中,我们忽略了以`.axd`为扩展名的资源文件。 2. `routes.MapPageRoute`:这个方法用于定义并注册ASP.NET Web Forms页面的路由规则。它将指定的URL模式映射到实际的物理文件,并可传递参数给目标页面。示例用法如下: ```csharp routes.MapPageRoute("ProductDetails", "products/{category}/{id}", "~/ProductDetails.aspx"); ``` 上述示例中,我们定义了一个名为"ProductDetails"的路由规则,将匹配形如`/products/electronics/123`的URL,并将请求路由到物理文件`ProductDetails.aspx`。其中,`{category}`和`{id}`是路由参数。 3. `routes.MapRoute`:这个方法用于定义并注册ASP.NET MVC控制器和动作方法的路由规则。它将指定的URL模式映射到相应的控制器和动作方法。示例用法如下: ```csharp routes.MapRoute( name: "Default", url: "{controller}/{action}/{id}", defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional } ); ``` 上述示例中,我们定义了一个名为"Default"的路由规则,将匹配形如`/Home/Index`的URL,并将请求路由到名为`HomeController`的控制器的`Index`动作方法。其中,`{controller}`、`{action}`和`{id}`是路由参数,`HomeController`和`Index`是默认值。 总结来说,`routes.IgnoreRoute`用于忽略某些URL,`routes.MapPageRoute`用于定义Web Forms页面的路由规则,而`routes.MapRoute`用于定义MVC控制器和动作方法的路由规则。它们各自适用于不同的场景和技术。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值