Discuz!官方免费开源建站系统

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

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

  [复制链接]
cr180 发表于 2010-9-18 21:09:51 | 显示全部楼层 |阅读模式
本帖最后由 cr180 于 2010-11-19 09:46 编辑
DISCUZ-x版本中,对css的处理较之前的版本更加智能化了,为了让更多的同学有个充分的理解,特把【黎明】的资料整理一下发给大家。

各位同学如果有疑问可以跟帖,但禁止任何AD,直接删除!

首先,每个页面都会加载以下两个类似的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,可以看到有这样的说明


  1. /** forum::index **/ 广场频道:首页 css代码开始
  2. 这里是css代码
  3. /** 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里面的合并了


评分

2

查看全部评分

 楼主| cr180 发表于 2010-9-18 22:13:05 | 显示全部楼层
沙发自己占了
回复

使用道具 举报

指间流沙 发表于 2010-9-18 22:14:32 | 显示全部楼层
cr180 发表于 2010-9-18 22:13
沙发自己占了

不厚道
回复

使用道具 举报

bingwei 发表于 2010-9-18 22:43:55 | 显示全部楼层
这个要支持下
回复

使用道具 举报

vmwenming 发表于 2010-9-19 17:46:25 | 显示全部楼层
帖子不错。 学习了。 正要自己做下模板
回复

使用道具 举报

pcyi 发表于 2010-9-20 01:09:47 | 显示全部楼层
难得啊、谢谢。
回复

使用道具 举报

teyla 发表于 2010-9-20 07:54:33 | 显示全部楼层
学习了,不错,顶下去
回复

使用道具 举报

linjeffery 发表于 2010-9-20 15:53:05 | 显示全部楼层
回复

使用道具 举报

pingye 发表于 2010-9-20 17:11:31 | 显示全部楼层
讨论得比较深入,支持
回复

使用道具 举报

jihuxi 发表于 2010-9-23 09:17:00 | 显示全部楼层
不是太懂,还在研究
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|Discuz! 官方站 ( 皖ICP备16010102号 )star

GMT+8, 2024-5-21 11:20 , Processed in 0.107426 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表