詳解Yii2 之 生成 URL 的方法
前言
在項目中,推薦使用 Yii2 內(nèi)置的 URL 工具類生成鏈接,這樣可以非常便捷的管理整站的 URL 行為:比如通過修改配置改變整站的URL格式等。URL 更多高級的用法參見官方文檔,這篇文章僅僅介紹 Yii2 生成 URL 的幾種方式。
Yii2 默認(rèn)的 URL 鏈接格式
Yii2 默認(rèn)的 URL 鏈接格式是指為開啟 URL 美化時的格式。
未啟用子模塊的 URL 格式:
// 參數(shù) r 中的 article 表示控制器, view 表示動作 http://www.example.com/index.php?r=article/view&id=100
啟用了子模塊的 URL 格式:
// 參數(shù) r 中的 kernel 表示子模塊 http://www.example.com/index.php?r=kernel/article/view&id=100
Yii2 內(nèi)置的 URL 生成工具
- URL 管理器:urlManager
- URL 助手類:yii\helpers\Url
使用內(nèi)置的 URL 生成工具,以后可以在不改變源碼的情況通過配置即可美化整站的 URL
URL 管理器
URL 管理器是一個名叫 urlManager 的內(nèi)置應(yīng)用組件。在 WEB 應(yīng)用和控制臺應(yīng)用中以通過以下兩種方式創(chuàng)建 URL:
- \Yii::$app->urlManager->createUrl($params)
- \Yii::$app->urlManager->createAbsoluteUrl($params, $schema = null)
createUrl
方法生成根目錄的相對路徑,例如:/index.php?r=article/view
createAbsoluteUrl()
方法生成的是絕對路徑,例如:http://www.example.com/index.php?r=article/view
常見的利用 URL 管理器創(chuàng)建 URL 的例子:
// URL:/index.php?r=article/view \Yii::$app->urlManager->createUrl('article/view'); // URL:/index.php?r=article/view&id=2 \Yii::$app->urlManager->createUrl(['article/view','id'=>2]); // URL: http://www.example.com?r=kernel/article/view echo \Yii::$app->urlManager->createAbsoluteUrl('kernel/article/view');
URL 助手類
相對于 URL管理器,使用 yii\helpers\Url
助手類可大大簡化 URL 的創(chuàng)建。
1. 假設(shè)當(dāng)前 URL /index.php?r=kernel/article/view&id=10
,以下說明 URL 助手類 Url::to()
是如何工作的(不推薦):
// 創(chuàng)建當(dāng)前 URL // 顯示:/?r=kernel/article/view&id=10 echo Url::to(); // 創(chuàng)建當(dāng)前 URL // 顯示:http://www.example.com/?r=kernel/article/view&id=10 echo Url::to('', true); // 字符參數(shù),沒啥用 // 顯示:kernel/article/view echo Url::to('kernel/article/view'); // 創(chuàng)建路由,數(shù)組參數(shù)的自動調(diào)用 Url::toRoute(...) // 顯示:/index.php?r=kernel/article/view echo Url::to(['article/view']);
2. 假設(shè)當(dāng)前 URL /index.php?r=kernel/article/view&id=10
,以下說明 URL 助手類 Url::toRoute()
方法是如何工作的(推薦):
// 創(chuàng)建當(dāng)前路由(僅繼承參數(shù)r的值) // 顯示:/index.php?r=kernel/article/view echo Url::toRoute([]); // 相同的模塊和控制器,不同的動作(僅繼承參數(shù)r的值) // 顯示:/index.php?r=kernel/article/list echo Url::toRoute('list'); // 相同的模塊和控制器,不同的動作(僅繼承參數(shù)r的值) // 顯示:/index.php?r=kernel/article/list&cat=contact echo Url::toRoute(['list','cat'=>10]); // 相同模塊,不同控制器和動作(僅繼承參數(shù)r的值) // 顯示:/index.php?r=kernel/product/index echo Url::toRoute('product/index'); // 絕對路由,不管是被哪個模塊和控制器調(diào)用 // 顯示:/index.php?r=product/index echo Url::toRoute('/product/index'); // 控制器動作 `actionListHot` 的 URL 格式(僅繼承參數(shù)r的值,區(qū)分大小寫) // 顯示:/index.php?r=kernel/article/list-hot echo Url::toRoute('list-hot'); // 從別名中獲取 URL // 顯示:http://www.baidu.com/ Yii::setAlias('@baidu', 'http://www.baidu.com/'); echo Url::to('@baidu');
3. 假設(shè)當(dāng)前 URL /index.php?r=kernel/article/view&id=10
,以下說明 URL 助手類 Url::current()
方法是如何工作的(推薦):
// 創(chuàng)建當(dāng)前 URL(包括路由和參數(shù)) // 顯示:/?r=kernel/article/view&id=10 echo Url::current(); // 移除參數(shù) id // 顯示:/?r=kernel/article/view echo Url::current(['id'=>null]); // 新增參數(shù) cat // 顯示:/?r=kernel/article/view&id=10&cat=2 echo Url::current(['cat'=>2]);
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Yii2創(chuàng)建控制器(createController)方法詳解
- yii2控制器Controller Ajax操作示例
- Yii2使用$this->context獲取當(dāng)前的Module、Controller(控制器)、Action等
- Yii2設(shè)置默認(rèn)控制器的兩種方法
- Yii2.0 Basic代碼中路由鏈接被轉(zhuǎn)義的處理方法
- yii2的restful api路由實例詳解
- Yii2針對指定url的生成及圖片等的引入方法小結(jié)
- Yii2框架自定義類統(tǒng)一處理url操作示例
- yii2 url重寫并隱藏index.php方法
- Yii2框架控制器、路由、Url生成操作示例
相關(guān)文章
重新認(rèn)識php array_merge函數(shù)
PHP中合并數(shù)組分成兩種情況:1.如果這兩個數(shù)組中有相同的字符串鍵名 2.如果這兩個數(shù)組中有相同的數(shù)值鍵名2014-08-08tp5(thinkPHP5框架)captcha驗證碼配置及驗證操作示例
這篇文章主要介紹了tp5(thinkPHP5框架)captcha驗證碼配置及驗證操作,結(jié)合實例形式分析了基于thinkPHP5框架的captcha驗證碼配置及驗證操作具體步驟與相關(guān)注意事項,需要的朋友可以參考下2019-05-05TP(thinkPHP)框架多層控制器和多級控制器的使用示例
這篇文章主要介紹了TP(thinkPHP)框架多層控制器和多級控制器的使用,結(jié)合實例形式分析了thinkPHP框架多層控制器和多級控制器的結(jié)構(gòu)、原理及使用方法,需要的朋友可以參考下2018-06-06淺析ThinkPHP中execute和query方法的區(qū)別
初學(xué)ThinkPHP的時候,很多人都對execute()和query()方法的區(qū)別搞不懂,本文就此淺析二者的區(qū)別,需要的朋友可以參考下2014-06-06