目錄
yii2源码学习笔记(十七),yii2源码学习笔记
首頁 後端開發 php教程 yii2源码学习笔记(十七),yii2源码学习笔记_PHP教程

yii2源码学习笔记(十七),yii2源码学习笔记_PHP教程

Jul 12, 2016 am 08:50 AM
yii

yii2源码学习笔记(十七),yii2源码学习笔记

Theme 类,应用的主题,通过替换路径实现主题的应用,方法为获取根路径和根链接:yii2\base\Theme.php

<span>  1</span> <?<span>php
</span><span>  2</span> <span>/*</span><span>*
</span><span>  3</span> <span> * @link </span><span>http://www.yiiframework.com/</span>
<span>  4</span> <span> * @copyright Copyright (c) 2008 Yii Software LLC
</span><span>  5</span> <span> * @license </span><span>http://www.yiiframework.com/license/</span>
<span>  6</span>  <span>*/</span>
<span>  7</span> 
<span>  8</span> <span>namespace</span> yii\<span>base</span><span>;
</span><span>  9</span> 
<span> 10</span> <span>use Yii;
</span><span> 11</span> <span>use yii\helpers\FileHelper;
</span><span> 12</span> 
<span> 13</span> <span>/*</span><span>*
</span><span> 14</span> <span> * Theme represents an application theme.
</span><span> 15</span> <span> * Theme 类,应用的主题
</span><span> 16</span> <span> * When [[View]] renders a view file, it will check the [[View::theme|active theme]]
</span><span> 17</span> <span> * to see if there is a themed version of the view file exists. If so, the themed version will be rendered instead.
</span><span> 18</span> <span> * 视图对象[[View]]渲染视图文件的时候,会检查视图的主题是否存在,如果存在则渲染主题取代默认样式
</span><span> 19</span> <span> * A theme is a directory consisting of view files which are meant to replace their non-themed counterparts.
</span><span> 20</span> <span> *
</span><span> 21</span> <span> * Theme uses [[pathMap]] to achieve the view file replacement:
</span><span> 22</span> <span> *
</span><span> 23</span> <span> * 1. It first looks for a key in [[pathMap]] that is a substring of the given view file path;
</span><span> 24</span> <span> *  首先查找关键字,关键字是一个给定的视图路径的字符串
</span><span> 25</span> <span> * 2. If such a key exists, the corresponding value will be used to replace the corresponding part
</span><span> 26</span> <span> *    in the view file path;关键字存在,则用对应值替换给定的视图文件路径中对应的部分
</span><span> 27</span> <span> * 3. It will then check if the updated view file exists or not. If so, that file will be used
</span><span> 28</span> <span> *    to replace the original view file.检查替换后的路径对应的文件是否存在,存在就替换原文件
</span><span> 29</span> <span> * 4. If Step 2 or 3 fails, the original view file will be used.
</span><span> 30</span> <span> * 2和3失败的话,返回原来的路径
</span><span> 31</span> <span> * For example, if [[pathMap]] is `['@app/views' => '@app/themes/basic']`,
</span><span> 32</span> <span> * then the themed version for a view file `@app/views/site/index.php` will be
</span><span> 33</span> <span> * `@app/themes/basic/site/index.php`.
</span><span> 34</span> <span> *
</span><span> 35</span> <span> * It is possible to map a single path to multiple paths. For example,
</span><span> 36</span> <span> *
</span><span> 37</span> <span> * ~~~
</span><span> 38</span> <span> * 'pathMap' => [
</span><span> 39</span> <span> *     '@app/views' => [
</span><span> 40</span> <span> *         '@app/themes/christmas',
</span><span> 41</span> <span> *         '@app/themes/basic',
</span><span> 42</span> <span> *     ],
</span><span> 43</span> <span> * ]
</span><span> 44</span> <span> * ~~~
</span><span> 45</span> <span> *
</span><span> 46</span> <span> * In this case, the themed version could be either `@app/themes/christmas/site/index.php` or
</span><span> 47</span> <span> * `@app/themes/basic/site/index.php`. The former has precedence over the latter if both files exist.
</span><span> 48</span> <span> *
</span><span> 49</span> <span> * To use a theme, you should configure the [[View::theme|theme]] property of the "view" application
</span><span> 50</span> <span> * component like the following:
</span><span> 51</span> <span> *
</span><span> 52</span> <span> * ~~~
</span><span> 53</span> <span> * 'view' => [
</span><span> 54</span> <span> *     'theme' => [
</span><span> 55</span> <span> *         'basePath' => '@app/themes/basic',
</span><span> 56</span> <span> *         'baseUrl' => '@web/themes/basic',
</span><span> 57</span> <span> *     ],
</span><span> 58</span> <span> * ],
</span><span> 59</span> <span> * ~~~
</span><span> 60</span> <span> *
</span><span> 61</span> <span> * The above configuration specifies a theme located under the "themes/basic" directory of the Web folder
</span><span> 62</span> <span> * that contains the entry script of the application. If your theme is designed to handle modules,
</span><span> 63</span> <span> * you may configure the [[pathMap]] property like described above.
</span><span> 64</span> <span> *
</span><span> 65</span> <span> * @property string $basePath The root path of this theme. All resources of this theme are located under this
</span><span> 66</span> <span> * directory.
</span><span> 67</span> <span> * @property string $baseUrl The base URL (without ending slash) for this theme. All resources of this theme
</span><span> 68</span> <span> * are considered to be under this base URL. This property is read-only.
</span><span> 69</span> <span> *
</span><span> 70</span> <span> * @author Qiang Xue <qiang.xue@gmail.com>
</span><span> 71</span> <span> * @since 2.0
</span><span> 72</span>  <span>*/</span>
<span> 73</span> <span>class</span><span> Theme extends Component
</span><span> 74</span> <span>{
</span><span> 75</span>     <span>/*</span><span>*
</span><span> 76</span> <span>     * @var array the mapping between view directories and their corresponding themed versions.
</span><span> 77</span> <span>     * This property is used by [[applyTo()]] when a view is trying to apply the theme.
</span><span> 78</span> <span>     * Path aliases can be used when specifying directories.
</span><span> 79</span> <span>     * 路径映射属性 设置替换映射关系
</span><span> 80</span> <span>     * If this property is empty or not set, a mapping [[Application::basePath]] to [[basePath]] will be used.
</span><span> 81</span>      <span>*/</span>
<span> 82</span>     <span>public</span><span> $pathMap;
</span><span> 83</span> 
<span> 84</span>     <span>private</span> $_baseUrl;<span>//</span><span>设置要访问资源的url</span>
<span> 85</span> 
<span> 86</span>     <span>/*</span><span>*
</span><span> 87</span> <span>     * @return string the base URL (without ending slash) for this theme. All resources of this theme are considered
</span><span> 88</span> <span>     * to be under this base URL. 返回当前主题的基础链接,其他资源都在链接里
</span><span> 89</span>      <span>*/</span>
<span> 90</span>     <span>public</span><span> function getBaseUrl()
</span><span> 91</span> <span>    {
</span><span> 92</span>         <span>return</span> $<span>this</span>-><span>_baseUrl;
</span><span> 93</span> <span>    }
</span><span> 94</span> 
<span> 95</span>     <span>/*</span><span>*
</span><span> 96</span> <span>     * @param $url string the base URL or path alias for this theme. All resources of this theme are considered
</span><span> 97</span> <span>     * to be under this base URL. 设置基础链接
</span><span> 98</span>      <span>*/</span>
<span> 99</span>     <span>public</span><span> function setBaseUrl($url)
</span><span>100</span> <span>    {
</span><span>101</span>         $<span>this</span>->_baseUrl = rtrim(Yii::getAlias($url), <span>'</span><span>/</span><span>'</span><span>);
</span><span>102</span> <span>    }
</span><span>103</span> 
<span>104</span>     <span>private</span> $_basePath;<span>//</span><span>根路径</span>
<span>105</span> 
<span>106</span>     <span>/*</span><span>*
</span><span>107</span> <span>     * @return string the root path of this theme. All resources of this theme are located under this directory.
</span><span>108</span> <span>     * 得到当前主题的根路径
</span><span>109</span> <span>     * @see pathMap
</span><span>110</span>      <span>*/</span>
<span>111</span>     <span>public</span><span> function getBasePath()
</span><span>112</span> <span>    {
</span><span>113</span>         <span>return</span> $<span>this</span>-><span>_basePath;
</span><span>114</span> <span>    }
</span><span>115</span> 
<span>116</span>     <span>/*</span><span>*
</span><span>117</span> <span>     * @param string $path the root path or path alias of this theme. All resources of this theme are located
</span><span>118</span> <span>     * under this directory. 设置当前主题根路径
</span><span>119</span> <span>     * @see pathMap
</span><span>120</span>      <span>*/</span>
<span>121</span>     <span>public</span><span> function setBasePath($path)
</span><span>122</span> <span>    {
</span><span>123</span>         $<span>this</span>->_basePath =<span> Yii::getAlias($path);
</span><span>124</span> <span>    }
</span><span>125</span> 
<span>126</span>     <span>/*</span><span>*
</span><span>127</span> <span>     * Converts a file to a themed file if possible. 将一个文件替换主题文件
</span><span>128</span> <span>     * If there is no corresponding themed file, the original file will be returned.
</span><span>129</span> <span>     * 没有相应的主题文件,返回原文件。
</span><span>130</span> <span>     * @param string $path the file to be themed
</span><span>131</span> <span>     * @return string the themed file, or the original file if the themed version is not available.
</span><span>132</span> <span>     * @throws InvalidConfigException if [[basePath]] is not set
</span><span>133</span>      <span>*/</span>
<span>134</span>     <span>public</span><span> function applyTo($path)
</span><span>135</span> <span>    {
</span><span>136</span>         $pathMap = $<span>this</span>->pathMap; <span>//</span><span>取得路径映射</span>
<span>137</span>         <span>if</span> (empty($pathMap)) {<span>//</span><span>没有设置值 抛出异常</span>
<span>138</span>             <span>if</span> (($basePath = $<span>this</span>->getBasePath()) === <span>null</span><span>) {
</span><span>139</span>                 <span>throw</span> <span>new</span> InvalidConfigException(<span>'</span><span>The "basePath" property must be set.</span><span>'</span><span>);
</span><span>140</span> <span>            }
</span><span>141</span>             <span>//</span><span>设置值为[模块根路径=>主题根路径]的形式</span>
<span>142</span>             $pathMap = [Yii::$app->getBasePath() =><span> [$basePath]];
</span><span>143</span> <span>        }
</span><span>144</span> 
<span>145</span>         $path = FileHelper::normalizePath($path);<span>//</span><span>对路径中的"/"."\"进行统一</span>
<span>146</span> 
<span>147</span>         <span>foreach</span> ($pathMap <span>as</span> $<span>from</span> =><span> $tos) {
</span><span>148</span>             <span>//</span><span>映射数组中的来源</span>
<span>149</span>             $<span>from</span> = FileHelper::normalizePath(Yii::getAlias($<span>from</span><span>)) . DIRECTORY_SEPARATOR;
</span><span>150</span>             <span>if</span> (strpos($path, $<span>from</span>) === <span>0</span>) {<span>//</span><span>如果在$path中有可替换的旧值</span>
<span>151</span>                 $n = strlen($<span>from</span><span>);
</span><span>152</span>                 <span>foreach</span> ((array) $tos <span>as</span><span> $to) {
</span><span>153</span>                     $to =<span> FileHelper::normalizePath(Yii::getAlias($to)) . DIRECTORY_SEPARATOR;
</span><span>154</span>                     $file = $to . substr($path, $n);<span>//</span><span>把$path中的$from替换为$to</span>
<span>155</span>                     <span>if</span><span> (is_file($file)) {
</span><span>156</span>                         <span>return</span> $file; <span>//</span><span>是文件直接返回</span>
<span>157</span> <span>                    }
</span><span>158</span> <span>                }
</span><span>159</span> <span>            }
</span><span>160</span> <span>        }
</span><span>161</span> 
<span>162</span>         <span>return</span><span> $path;
</span><span>163</span> <span>    }
</span><span>164</span> 
<span>165</span>     <span>/*</span><span>*
</span><span>166</span> <span>     * Converts a relative URL into an absolute URL using [[baseUrl]].
</span><span>167</span> <span>     * 将一个相对URL转换为绝对URL
</span><span>168</span> <span>     * @param string $url the relative URL to be converted.要转换的相对URL
</span><span>169</span> <span>     * @return string the absolute URL  替换后的绝对URL
</span><span>170</span> <span>     * @throws InvalidConfigException if [[baseUrl]] is not set
</span><span>171</span>      <span>*/</span>
<span>172</span>     <span>public</span><span> function getUrl($url)
</span><span>173</span> <span>    {
</span><span>174</span>         <span>if</span> (($baseUrl = $<span>this</span>->getBaseUrl()) !== <span>null</span>) {<span>//</span><span>URL存在,进行转换</span>
<span>175</span>             <span>return</span> $baseUrl . <span>'</span><span>/</span><span>'</span> . ltrim($url, <span>'</span><span>/</span><span>'</span><span>);
</span><span>176</span>         } <span>else</span> {<span>//</span><span>不存在抛出异常</span>
<span>177</span>             <span>throw</span> <span>new</span> InvalidConfigException(<span>'</span><span>The "baseUrl" property must be set.</span><span>'</span><span>);
</span><span>178</span> <span>        }
</span><span>179</span> <span>    }
</span><span>180</span> 
<span>181</span>     <span>/*</span><span>*
</span><span>182</span> <span>     * Converts a relative file path into an absolute one using [[basePath]].
</span><span>183</span> <span>     * 通过相对路径生成绝对路径
</span><span>184</span> <span>     * @param string $path the relative file path to be converted. 要转换的相对文件路径。
</span><span>185</span> <span>     * @return string the absolute file path 转换后的绝对路径
</span><span>186</span> <span>     * @throws InvalidConfigException if [[baseUrl]] is not set
</span><span>187</span>      <span>*/</span>
<span>188</span>     <span>public</span><span> function getPath($path)
</span><span>189</span> <span>    {
</span><span>190</span>         <span>if</span> (($basePath = $<span>this</span>->getBasePath()) !== <span>null</span><span>) {
</span><span>191</span>             <span>//</span><span>返回拼接的路径</span>
<span>192</span>             <span>return</span> $basePath . DIRECTORY_SEPARATOR . ltrim($path, <span>'</span><span>/\\</span><span>'</span><span>);
</span><span>193</span>         } <span>else</span><span> {
</span><span>194</span>             <span>throw</span> <span>new</span> InvalidConfigException(<span>'</span><span>The "basePath" property must be set.</span><span>'</span><span>);
</span><span>195</span> <span>        }
</span><span>196</span> <span>    }
</span><span>197</span> }
登入後複製

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1134780.htmlTechArticleyii2源码学习笔记(十七),yii2源码学习笔记 Theme 类,应用的主题,通过替换路径实现主题的应用,方法为获取根路径和根链接:yii2\base\T...
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用PHP框架Yii開發一個高可用的雲端備份系統 如何使用PHP框架Yii開發一個高可用的雲端備份系統 Jun 27, 2023 am 09:04 AM

隨著雲端運算技術的不斷發展,資料的備份已經成為了每個企業必須要做的事情。在這樣的背景下,開發一款高可用的雲端備份系統尤其重要。而PHP框架Yii是一款功能強大的框架,可以幫助開發者快速建立高效能的Web應用程式。以下將介紹如何使用Yii框架開發一款高可用的雲端備份系統。設計資料庫模型在Yii框架中,資料庫模型是非常重要的一環。因為資料備份系統需要用到很多的表和關

Symfony vs Yii2:哪個框架比較適合開發大型Web應用? Symfony vs Yii2:哪個框架比較適合開發大型Web應用? Jun 19, 2023 am 10:57 AM

隨著Web應用需求的不斷增長,開發者在選擇開發框架方面也越來越有選擇的空間。 Symfony和Yii2是兩個備受歡迎的PHP框架,它們都具有強大的功能和效能,但在面對需要開發大型網路應用程式時,哪個框架更適合呢?接下來我們將對Symphony和Yii2進行比較分析,以幫助你更好地進行選擇。基本概述Symphony是一個由PHP編寫的開源Web應用框架,它是建立

php如何使用Yii3框架? php如何使用Yii3框架? May 31, 2023 pm 10:42 PM

隨著互聯網的不斷發展,Web應用程式開發的需求也越來越高。對於開發人員而言,開發應用程式需要一個穩定、高效、強大的框架,這樣可以提高開發效率。 Yii是一款領先的高效能PHP框架,它提供了豐富的特性和良好的性能。 Yii3是Yii框架的下一代版本,它在Yii2的基礎上進一步優化了效能和程式碼品質。在這篇文章中,我們將介紹如何使用Yii3框架來開發PHP應用程式。

Yii2 vs Phalcon:哪個框架更適合開發顯示卡渲染應用? Yii2 vs Phalcon:哪個框架更適合開發顯示卡渲染應用? Jun 19, 2023 am 08:09 AM

在當前資訊時代,大數據、人工智慧、雲端運算等技術已成為了各大企業關注的熱點。在這些技術中,顯示卡渲染技術作為一種高效能圖形處理技術,受到了越來越多的關注。顯示卡渲染技術廣泛應用於遊戲開發、影視特效、工程建模等領域。而對於開發者來說,選擇一個適合自己專案的框架,是一個非常重要的決策。在目前的語言中,PHP是一種相當有活力的語言,一些優秀的PHP框架如Yii2、Ph

Yii框架中的資料查詢:有效率地存取數據 Yii框架中的資料查詢:有效率地存取數據 Jun 21, 2023 am 11:22 AM

Yii框架是一個開源的PHPWeb應用程式框架,提供了眾多的工具和元件,簡化了Web應用程式開發的流程,其中資料查詢是其中一個重要的元件之一。在Yii框架中,我們可以使用類似SQL的語法來存取資料庫,從而有效率地查詢和操作資料。 Yii框架的查詢建構器主要包括以下幾種類型:ActiveRecord查詢、QueryBuilder查詢、命令查詢和原始SQL查詢

Yii2程式設計指南:執行Cron服務的方法 Yii2程式設計指南:執行Cron服務的方法 Sep 01, 2023 pm 11:21 PM

如果您問「Yii是什麼?」請參閱我之前的教學:Yii框架簡介,其中回顧了Yii的優點,並概述了2014年10月發布的Yii2.0的新增功能。嗯>在這個使用Yii2程式設計系列中,我將指導讀者使用Yii2PHP框架。在今天的教學中,我將與您分享如何利用Yii的控制台功能來執行cron作業。過去,我在cron作業中使用了wget—可透過Web存取的URL來執行我的後台任務。這引發了安全性問題並存在一些效能問題。雖然我在我們的啟動系列安全性專題中討論了一些減輕風險的方法,但我曾希望過渡到控制台驅動的命令

Yii2 vs Symfony:哪個框架比較適合API開發? Yii2 vs Symfony:哪個框架比較適合API開發? Jun 18, 2023 pm 11:00 PM

隨著網路的快速發展,API成為了各種應用間資料交換的重要方式。因此,開發一款易於維護、高效、穩定的API框架變得越來越重要。而在選擇API框架時,Yii2和Symfony是兩個備受開發者歡迎的選擇。那麼,哪一個比較適合API開發呢?本文將對這兩個框架進行比較,並給出一些結論。一、基本介紹Yii2和Symfony都是成熟的PHP框架,都有相應的擴展,可以用來開

yii如何將物件轉換為陣列或直接輸出為json格式 yii如何將物件轉換為陣列或直接輸出為json格式 Jan 08, 2021 am 10:13 AM

yii框架:本文為大家介紹了yii將物件轉換為陣列或直接輸出為json格式的方法,具有一定的參考價值,希望能幫助大家。

See all articles