Yii2.0-advanced-8—主题配置(themes)

界面主题

界面主题(theme)是一个视图和布局文件目录。每个主题中的文件用于在渲染时覆盖相应的应用程序文件。可以为一个应用程序开发具有不同用户体验的界面主题,但任何时候只能有一个被激活。

界面主题配置

界面主题配置通过应用程序的 view 组件来指定。在高级应用程序中backend要使用界面主题,可配置如下:

'components' => [
    'view' => [
        'theme' => [
            'pathMap' => ['@backend/views' => '@frontend/themes/blog/views'],
            'baseUrl' => '@web/themes/blog',
        ],
    ],
],

在上述的 pathMap 中,定义了原路径到主题路径的映射表,

而 baseUrl 定义了主题中所引用的资源的基础路径,每一套themes配一套样式;

在我们的例子中,pathMap 是 ['@backend/views' => '@backend/themes/blog/views']。这意味着所有@backend/views 中的视图将首先查找 @backend/themes/blog/views目录,如果找到了则将使用该视图文件,而不是原视图。

比如,通过上述的配置, @backend/views/site/index.php 视图文件的一个主题化版本会是 @backend/themes/blog/views/site/index.php。

基本上就是把路径中的 @backend/views 替换为 @backend/themes/blog/views。

实例:

以高级版为例

1.在frontend中新建themes文件夹作为主题文件,里面创建一个博客主题文件夹blog

2.在frontend/web中也创建步骤一中的文件目录,即frontend/web/themes/blog

这样我们的主题就算搭建完成了,但打开页面并没有任何效果,原因是我们并没有在我们的主题中添加任何主题文件,从原理中我们得知,系统会先去主题目录中获取对应的视图,没有则会调用默认的视图。

那么我们新建一个主题文件,打开frontend/themes/blog,新建views/site/index.php index.php为空

然后在backend/web中将css这个文件目录整个拷贝到web中的themes文件夹中

如下图所示:

blob.png

然后登录访问我们的backend主页,会发现一个空白的界面,这说明主题的调用已经成功了,后面我们就可以在这个主题中创建属于自己的主题代码了

好了,那么主题的简单用例就是这样子了

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值