"路由地址和参数", "路由规" />
牛骨文教育服务平台(让学习变的简单)

批量注册

批量注册路由规则可以使用两种方式,包括方法注册和路由配置定义。

批量注册

如果不希望一个个注册,可以使用批量注册,规则如下:

Route::rule([
"路由规则1"=>"路由地址和参数",
"路由规则2"=>["路由地址和参数","匹配参数(数组)","变量规则(数组)"]
...
],"","请求类型","匹配参数(数组)","变量规则");

如果在外面和规则里面同时传入了匹配参数和变量规则的话,路由规则定义里面的最终生效,但请求类型参数以最外层决定,例如:

Route::rule([
    "new/:id"  =>  "News/read",
    "blog/:id" =>  ["Blog/update",["ext"=>"shtml"],["id"=>"d{4}"]],
    ...
],"","GET",["ext"=>"html"],["id"=>"d+"]);

以上的路由注册,最终blog/:id只会在匹配shtml后缀的访问请求,id变量的规则则是 d{4}

如果不同的请求类型的路由规则是一样的,为了避免数组索引冲突的问题,请使用单独的请求方法定义路由。

同样,我们也可以使用其他几个注册方法进行批量注册。

// 批量注册GET路由
Route::get([
    "new/:id"  =>  "News/read",
    "blog/:id" =>  ["Blog/edit",[],["id"=>"d+"]]
    ...
]);
// 效果等同于
Route::rule([
    "new/:id"  =>  "News/read",
    "blog/:id" =>  ["Blog/edit",[],["id"=>"d+"]]
    ...
],"","GET");

定义路由配置文件

除了支持动态注册,也可以直接在应用目录下面的route.php 的最后通过返回数组的方式直接定义路由规则,内容示例如下:

return [
    "new/:id"   => "News/read",
    "blog/:id"   => ["Blog/update",["method" => "post|put"], ["id" => "d+"]],
];

路由配置文件定义的路由规则效果和使用any注册路由规则一样。

路由动态注册和配置定义的方式可以共存,例如:

use thinkRoute;

Route::rule("hello/:name","index/index/hello");

return [
    "new/:id"   => "News/read",
    "blog/:id"   => ["Blog/update",["method" => "post|put"], ["id" => "d+"]],
];

默认情况下,只会加载一个路由配置文件route.php,如果你需要定义多个路由文件,可以修改route_config_file配置参数,例如:

// 定义路由配置文件(数组)
"route_config_file" =>  ["route", "route1", "route2"],

如果存在相同的路由规则,一样可以参考前面的批量注册方式进行定义。

由于检测机制问题,动态注册的性能比路由配置要高一些,尤其是多种请求类型混合定义的时候。