U方法用於完成對URL位址的組裝,特點在於可以自動根據當前的URL模式和設置生成對應的URL位址,格式為:
U('位址','參數','偽靜態','是否跳轉','顯示功能變數名稱');
在範本中使用U方法而不是固定寫死URL位址的好處在於,一旦你的環境變化或者參數設置改變,你不需要更改範本中的任何代碼。
在範本中的調用格式需要採用 {:U('位址', '參數'...)} 的方式
U方法的用法示例:
U('User/add')&HTTP://www.aliyun.com/zixun/aggregation/37954.html">nbsp;// 生成User模組的add操作位址
也可以支援分組調用:
U('Home/User/add') // 生成Home分組的User模組的add操作位址
當然,也可以只是寫操作名,表示調用當前模組的
U('add') // 生成當前訪問模組的add操作位址
除了分組、模組和操作名之外,我們也可以傳入一些參數:
U('Blog/read?id=1') // 生成Blog模組的read操作 並且id為1的URL位址
U方法的第二個參數支援傳入參數,支援陣列和字串兩種定義方式,如果只是字串方式的參數可以在第一個參數中定義,下面幾種方式都是等效的:
U('Blog/cate',array('cate_id'=>1,'status'=>1))U('Blog/cate','cate_id=1&status=1')U('Blog/cate? cate_id=1&status=1')
但是不允許使用下面的定義方式來傳參數:
U('Blog/cate/cate_id/1/status/1')
根據專案的不同URL設置,同樣的U方法調用可以智慧地對應產生不同的URL位址效果,例如針對:
U('Blog/read?id=1')
這個定義為例。
如果當前URL設置為普通模式的話,最後生成的URL位址是:
HTTP://serverName/index.php?m=Blog&a=read&id=1
如果當前URL設置為PATHINFO模式的話,同樣的方法最後生成的URL位址是:
HTTP://serverName/index.php/Blog/read/id/1
如果當前URL設置為REWRITE模式的話,同樣的方法最後生成的URL位址是:
HTTP://serverName/Blog/read/id/1
如果你同時還設置了PATHINFO分隔符號的話:
'URL_PATHINFO_DEPR'=>'_'
就會生成
HTTP://serverName/Blog_read_id_1
如果當前URL設置為REWRITE模式,並且設置了偽靜態尾碼為html的話,同樣的方法最後生成的URL位址是:
HTTP://serverName/Blog/read/id/1.html
如果設置了多個偽靜態支援,那麼會自動取第一個偽靜態尾碼添加到URL位址後面,當然你也可以手動在U方法裡面指定要生成的偽靜態尾碼,例如:
U('Blog/read','id=1','xml')
就會生成
HTTP://serverName/Blog/read/id/1.xml
U方法還可以支援路由,如果我們定義了一個路由規則為:
'news/:id\d'=>'News/read'
那麼可以使用
U('/news/1')
最終生成的URL位址是:
HTTP://serverName/index.php/news/1
如果你的應用涉及到多個子功能變數名稱的操作位址,那麼也可以在U方法裡面指定需要生成位址的功能變數名稱,例如:
U('Blog/read@blog.thinkphp.cn','id=1');
@後面傳入需要指定的功能變數名稱即可。
此外,U方法的第5個參數如果設置為true,表示自動識別當前的功能變數名稱,並且會自動根據子功能變數名稱部署設置APP_SUB_DOMAIN_DEPLOY和APP_SUB_DOMAIN_RULES自動匹配生成當前位址的子功能變數名稱。
如果開啟了URL_CASE_INSENSITIVE,則會統一生成小寫的URL位址。