通過路由分組可以快速為具有共同屬性的路由建立規則,例如:
~~~~~~
// 原型 router::group(array $in, $mixRouter);
router::group('公共屬性', '路由或者閉包');
~~~
# 支持參數
公共屬性包含以下多種情況,下面將一一說明。
## 路由域名
分組路由中可以指定域名,這樣每一個路由都具備了域名匹配功能,域名中支持參數。
~~~
router::group ( [
'domain' => '{domain}.queryphp.com'
], [
[
'new-{id}-{name}',
'home://new/index'
],
[
'hello-{goods}',
'home://goods/index'
]
] );
~~~
## 路由前綴
如果你需要為一個數組中的所有路由加上前綴,可以在路由中指定前綴 prefix。
~~~
router::group ( [
'prefix' => 'admin-'
], [
[
'new-{id}-{name}',
'home://new/index'
],
[
'hello-{goods}',
'home://goods/index'
]
] );
~~~
訪問地址
~~~
http://<service>/admin-hello-123456
~~~
解析后的 GET 值如下:
~~~
Array
(
[app] => home
[c] => goods
[a] => index
[goods] => 123456
)
~~~
## 附加參數
系統在匹配路由的時候,可以為匹配的結果附加上結果,解析變量的可以覆蓋此值。
~~~
router::group ( [
'params' => [
'args1' => '小',
'args2' => '大'
]
], [
[
'new-{id}-{name}',
'home://new/index'
],
[
'hello-{goods}',
'home://goods/index'
]
] );
~~~
訪問地址
~~~
http://<service>/hello-123456
~~~
解析后的 GET 值如下
~~~
Array
(
[app] => home
[c] => goods
[a] => index
[args1] => 小
[args2] => 大
[goods] => 123456
)
~~~
## 參數正則
我們可以在分組中統一指定參數正則,路由內部的參數具有優先級。
~~~
router::group ( [
'where' => [
'id' => '[0-9]+',
'name' => '[a-z]+'
]
], [
[
'new-{id}-{name}',
'home://new/index'
],
[
'hello-{goods}',
'home://goods/index'
]
] );
~~~
## 插入順序
插入將在遇到相同路由的時候,具有優先匹配的權利。
~~~
router::group ( [
'prepend' => true
], [
[
'new-{id}-{name}',
'home://new/index'
],
[
'hello-{goods}',
'home://goods/index'
]
] );
~~~
## 嚴格模式
嚴格模式讓 url 匹配精準一些,請根據項目具體分析。
~~~
router::group ( [
'prepend' => true
], [
[
'new-{id}-{name}',
'home://new/index'
],
[
'hello-{goods}',
'home://goods/index'
]
] );
~~~
# 閉包注冊
我們可以在分組路由中采用閉包注冊路由,公共屬性將會傳入規則中。
~~~
router::group ( [
'prefix' => 'myprefix-'
], function () {
router::import ( 'new-{id}-{name}', 'home://new/index' );
router::import ( 'hello-{goods}', 'home://goods/index' );
} );
~~~
嵌套支持
~~~
router::group ( [
'prefix' => 'myprefix-'
], function () {
router::group ( [
'params' => [
'args1' => '你',
'args2' => '好'
]
], function () {
router::import ( 'new-{id}-{name}', 'home://new/index' );
router::import ( 'hello-{goods}', 'home://goods/index' );
} );
} );
~~~
- 關于 QueryPHP
- 獲取 QueryPHP
- 環境要求
- 許可協議 Free
- 執行流程 MVC
- 命名規范 $sName
- 目錄結構 DIR
- 單一入口 index.php
- 響應客戶端請求 URL
- 命名空間與自動載入 Autoload
- 路由
- 路由導入
- 批量導入
- 參數正則
- 分組定義
- 路由綁定
- 路由域名
- 分層控制器
- 默認和初始化APP
- 默認控制器和方法
- url 模式
- url 生成
- url 偽靜態
- url 重寫
- url 重定向
- 控制器綁定
- 方法器分層
- 控制器 __init
- 控制器方法交互
- 模板引擎語法
- C變量輸出 $sName
- C變量支持函數和方法 $sName|trim
- C快捷輸出 ~
- C標簽簡化 Css & Javascript
- C默認值 eq 三元運算符
- C變量運算符 +-
- 變量遞增遞減 ++--
- C循環數據 list
- N變量賦值 assign
- N循環數據 list
- N循環數據高級版 lists
- C循環數據 while
- N循環數據 while
- C循環數據 for
- N循環數據 for
- C條件判斷 if
- N條件判斷 if
- 標簽嵌套無限層級
- N循環流程 break & continue
- N使用 PHP 代碼
- N包含子模板 include
- J模板引擎 intro
- J條件判斷 if
- J循環數據 each
- J變量 & 表達式
- J變量支持函數和方法 hello|test
- J默認值 eq 三元運算符
- J框架前端組件 jquery.queryphp.js
- J前端 CSS 規范
- J前端 JS 規范
- 保護標簽自身 tagself
- 數據庫
- 數據庫配置
- 執行原生 sql 語句
- 數據庫事務
- 數據庫構造器 prefix
- 數據庫構造器 table
- 數據庫構造器 forceIndex
- 數據庫構造器 where
- 數據庫構造器 bind
- 數據庫構造器 join
- 數據庫構造器 union
- 數據庫構造器 orderBy
- 數據庫構造器 groupBy
- 數據庫構造器 having
- 數據庫構造器 distinct
- 數據庫構造器 aggregate
- 數據庫構造器 limit
- 數據庫構造器 forUpdate
- 數據庫構造器 columns
- 數據庫構造器 reset
- 數據庫集合查詢
- 數據庫查詢數據 get
- 數據庫查詢多條數據 getAll
- 數據庫查詢單條數據 getOne
- 數據庫查詢聚合查詢 aggregate
- 數據庫寫入數據 insert
- 數據庫寫入數據 insertAll
- 配置
- 配置格式
- 慣性配置
- 配置文件
- 讀取配置
- 設置配置
- 刪除配置
- 日志
- 日志配置參數
- 日志路徑
- 日志過濾器
- 日志處理器
- 緩存
- 緩存配置參數
- 緩存路徑
- 緩存指定時間
- COOKIE
- COOKIE 配置參數
- 開發調試
- 頁面 trace