Yii2主題(Theme)用法詳解
來(lái)源:易賢網(wǎng) 閱讀:1505 次 日期:2016-08-11 14:11:07
溫馨提示:易賢網(wǎng)小編為您整理了“Yii2主題(Theme)用法詳解”,方便廣大網(wǎng)友查閱!

本文實(shí)例講述了Yii2主題(Theme)用法。分享給大家供大家參考,具體如下:

首先看看主要的配置方式:

'components' => [

  'view' => [

    'theme' => [

      'pathMap' => ['@app/views' => '@app/themes/basic'],

      'baseUrl' => '@web/themes/basic',

    ],

  ],

],

Yii中的主題功能主要由yii\base\Theme類來(lái)實(shí)現(xiàn),它的主要思想是:先定義好一個(gè)一一對(duì)應(yīng)的字符串映射數(shù)組,然后對(duì)給定的字符串按照數(shù)組中的映射關(guān)系進(jìn)行字符串替換。

有如下映射:

$pathMap=[

    '@app/a' => '@app/aaa',

    '@app/b' => '@app/bbb',

    '@app/c' => [

        '@app/ccc/xxx',

        '@app/ccc/yyy',

      ],

];

對(duì)字符串 @app/a/site/index.php,由上面的映射關(guān)系可知會(huì)把@app/a替換為@app/aaa,生成結(jié)果為@app/aaa/site/index.php。

但要注意,這個(gè)還不是最終的結(jié)果。由于在Yii中是對(duì)文件路徑的操作,所以如果@app/aaa/site/index.php這個(gè)文件存在的話,則會(huì)返回這個(gè)路徑,否則返回原路徑即:@app/a/site/index.php

如果有字符串@app/c/site/index.php,由于上面的映射知道@app/c對(duì)應(yīng)2個(gè)替換項(xiàng),Yii會(huì)從前開(kāi)始依次替換,先生成@app/ccc/xxx/site/index.php,如果這個(gè)文件存在,則返回這個(gè)路徑,否則繼續(xù)替換。

如果所有的替換結(jié)果都不存在對(duì)應(yīng)的文件,那么最后返回原路徑。

同時(shí)寫多個(gè)替換的目標(biāo)值有這么一個(gè)好處:實(shí)現(xiàn)主題的繼承。

現(xiàn)在有一套默認(rèn)的主題default,如果現(xiàn)在要增加一套黑色的主題,有兩個(gè)辦法可以實(shí)現(xiàn)。

第一種:把所有的default中的視圖全部復(fù)制一份到blank目錄中。

第二種:只復(fù)制一份layout布局文件到blank目錄中,然后在布局文件中修改整體顏色。然后設(shè)置為:

$pathMap=[

    '@app/c' => [

        '@app/ccc/blank',

        '@app/ccc/default',

      ],

];

好處看到了吧,如果在blank中沒(méi)有找到文件,會(huì)從default中來(lái)查找,也就是說(shuō)blank中的文件會(huì)覆蓋default中存在的文件,從而實(shí)現(xiàn)了主題的繼承。

主題中的屬性:

$pathMap:這個(gè)就是用來(lái)設(shè)置替換映射關(guān)系的。

'pathMap' =>[

    '@app/views' => [

        '@app/themes/blank',

        '@app/themes/default',

    ],

    '@app/modules' => '@app/themes/default/modules',

    '@app/widgets' => '@app/themes/default/widgets'

],

這三個(gè)分別對(duì)views、modules和widgets應(yīng)用主題。

$baseUrl:這個(gè)用來(lái)設(shè)置要訪問(wèn)的資源的url(結(jié)尾不加“/”)

$basePath:設(shè)置資源所在的文件目錄

主題中的方法:

public function init()

{

    parent::init();

    //如果沒(méi)有設(shè)置$pathMap映射,則使用$basePath,

    if (empty($this->pathMap)) {

        /*

         * 如果$basePath也沒(méi)有設(shè)置,則出異常。

         * 也就是說(shuō) $pathMap和$basePath至少要設(shè)置一個(gè),如果兩個(gè)都設(shè)置了,優(yōu)先使用$pathMap

         */

      if (($basePath = $this->getBasePath()) === null) {

        throw new InvalidConfigException('The "basePath" property must be set.');

      }

      //設(shè)置當(dāng)前模塊的路徑和$basePath的映射關(guān)系

      $this->pathMap = [Yii::$app->getBasePath() => [$basePath]];

    }

}

public function applyTo($path)

//這個(gè)就是按照 $pathMap中的定義的映射關(guān)系來(lái)對(duì)$path進(jìn)行替換字符串的

public function applyTo($path)

{

    //對(duì)路徑中的"/"、“\”進(jìn)行統(tǒng)一替換

    $path = FileHelper::normalizePath($path);

    foreach ($this->pathMap as $from => $tos) {

       //映射數(shù)組中的來(lái)源(舊值)

      $from = FileHelper::normalizePath(Yii::getAlias($from)) . DIRECTORY_SEPARATOR;

      //如果在$path中有可替換的舊值

      if (strpos($path, $from) === 0) {

        $n = strlen($from);

        //對(duì)目標(biāo)值循環(huán),

        foreach ((array) $tos as $to) {

          $to = FileHelper::normalizePath(Yii::getAlias($to)) . DIRECTORY_SEPARATOR;

          //把$path中的$from替換為$to

          $file = $to . substr($path, $n);

          //如果是文件,直接返回

          if (is_file($file)) {

            return $file;

          }

        }

      }

    }

    return $path;

}

希望本文所述對(duì)大家基于Yii框架的PHP程序設(shè)計(jì)有所幫助。

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:Yii2主題(Theme)用法詳解
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)