Discuz-x系列教程 DX的css命名规则、缓存、加载机制

所属分类: CMS教程 / discuz 阅读数: 1755
收藏 0 赞 0 分享
首先,每个页面都会加载以下两个类似的css:
data/cache/style_1_common.css
data/cache/style_1_forum_index.css

一、两个文件名的命名规则

style_1_common.css
|--是整站通用的全局css,所以命名为【style_1_common.css】
|--前面的代号是当前使用这套风格的ID,所以style_1_common.css也就是第一套风格的共用的css

style_1_forum_index.css
|--是【forum】广场BBS频道首页的css样式,那么forum和index分别对应这CURSCRIPT和CURMODULE的常量值,这个在每个频|--道的入口脚本里都有定义,比如forum频道页面对应的是forum.php。

以上介绍的是css的缓存加载文件,当然,还有一些在特殊页面的css,这里就不详细描述了。

这两个css文件的生成

首先,那两个css是程序生成的css缓存文件,所以如果要改css的话,不能直接改那两个文件,否则一更新缓存,之前的改动就无效了。
拿自带的default模板举例吧,default模板中,带有一个common的文件夹,这个文件夹存放的是全局模板文件,
里面有css文件:
style_1_common.css 是【common.css】生成的缓存
style_1_forum_index.css 是【module.css】生成的缓存

二、module.css的缓存和加载机制

打开module.css,可以看到有这样的说明

复制代码
代码如下:

/** forum::index **/ 广场频道:首页 css代码开始
这里是css代码
/** end **/ 广场首页css代码结束

这就是经常在模板中用到的判断,程序读取这个css文件的内容,通过标识进行判断,最后把符合条件内的所有css生成在一个对应的缓存文件中。

再举个例子:
/** forum::index,forum::viewthread **/ 广场频道:首页模块和帖子阅读页CSS代码开始
这里是css代码
/** end **/ 结束
第二个例子大家应该知道了,就是再增加一个条件,这里可以不止两个:
/** forum::index,forum::viewthread,forum::forumdisplay,XXXX **/

ok,根据自己的需要来加就行了,记得符号【,】
大家可以参照这个学习一下,包括你想扩展他,都可以直接在里面直接添加就可以。

下面讲讲缓存css是如何生成的

common.css比较简单,就是直接读取,然后生成到data/cache目录下。

每个频道模块独立的css,会先将module.css在data/cache下生成一个对应的风格id下的缓存的css,然后当你访问某个频道时,会生成对应频道下的css,此时,刚才介绍的那些标识就起作用了。程序会根据/** group::index **/和/** end **/这种标识,拆分出哪些频道、哪些模块该需要哪些css。

程序部分就不介绍了,程序的代码主要在source/class/class_template.php文件处理,有兴趣的同学可以深入研究一下。


三、在模板制作中充分的运用好css加载机制,提高页面的加载速度

新建模板后同学们可以在【模板文件夹\common】中建立附加样式表并命名为:
extend_module.css
extend_common.css
这两个css文件就是重新定义common.css与module.css里面的样式,这两个附加样式与上面讲的两个css文件分别合并,最终就生成css缓存文件了

extend_module.css 这里面必须根据上面第二节里讲的,写好标识!!

如果想重新定义默认模板中的一些css,那么直接在这两个文件中重写就行了。

注意:如果你的模板布局是完全要重写的,那就命名为:common.css和module.css 这样程序就只处理新模板中的css,不会与default里面的合并了
更多精彩内容其他人还在看

DiscuzX发帖默认隐藏附件/图片/链接/视频等设置教程

DiscuzX在发帖过程中会有很多我们不想看到的选项可以默认隐藏附件/图片/链接/视频吗?答案是可以的,感兴趣的你可以参考下本文哈,希望可以帮助到你
收藏 0 赞 0 分享

Discuz!x3版块及分区可选择性设置是否显示在导航中

很多站长长年累月的自己把导航改完又改,无非是想把自己的版块都一目了然的放上去导航中,很容易实现的效果却变得如此复杂,Discuz!x3新功能帮助站长朋友们实现了这一点,感兴趣的你可以不要错过本文了哈
收藏 0 赞 0 分享

Discuz! X2.5与UCenter通信失败常见症状及解决方法

UCenter通信失败是Discuz站长们经常遇见的问题之一;如上传头像时报错、新会员无法注册、登录密码不正确等一系列的问题,接下来与大家分享UCenter 通信失败的解决方法
收藏 0 赞 0 分享

Discuz! X2.5定时发帖新功能开启方法(图文)

Discuz! X2.5新增了很多功能,比如定时发帖,很方便的功能会节省很多的时间,听说安装之后无法实现,接下来为大家详细介绍下到底该如何设置,感兴趣的你可千万不要错过了哈,希望可以帮助到你
收藏 0 赞 0 分享

Discuz如何设置腾讯微博来源(图文步骤)

在微博开放平台创建应用后,请提交审核,应用通过审核后来源才能生效,来源生效后微博才会显示您的网站名称哦,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

Discuz!开启使用HTML、主题分类、分类信息的方法

好多新手站长对于HTML的开启、使用,分类信息的开启、使用都很茫然,不知道从哪里下手,或者自己设置了但是却不能正常使用。希望下面的讲解对这些新手站长有所帮助
收藏 0 赞 0 分享

discuz不修改代码达到允许referer跳转到同顶级域名的解决方案

查看了discuz的drerferer方法.发现它不允许跳转到不同子域名的跳转,下面与大家分享下使用一个不变动的方式来增加跳转功能,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

discuz 批量删除的sql命令小结

这篇文章主要介绍了discuz 批量删除内容的一些sql语句,比去后台选择的方便
收藏 0 赞 0 分享

discuz修改太阳、月亮、星星等默认等级图标的方法

想修改一下默认的等级图标,先把你的等级图片在论坛用附件的形式发表在帖子中,然后按右键查看属性,这就是要替换的地址,具体的修改方法如下,有需要的朋友可以参考下,希望对大家有所帮助
收藏 0 赞 0 分享

Discuz 模板目录结构注释说明详细整理

本文为大家整理了一些使用使用是常接触的Discuz 模板目录结构与注释说明,有需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多