discuz! X 前端文档(HTML和CSS部分)
+ e6 t+ d2 g( Y1 V3 R( D: J" b( EDiscuz!X 前端文档(HTML和css部分)
9 E" b8 c" D* `( X: W
& l0 D( B3 o7 }' V- `% l9 g( P3 M默认模板文件构成... 1
# G+ K3 z7 u1 W& p: B9 {默认模板的图片文件构成... 2
$ o1 ^9 I% p* c: b默认模板修改原则... 3
7 J K/ ^! w6 `: M默认模板中的一些“陷阱”... 3
" G' @. g* x- l3 i; b
需要兼容的浏览器列表... 4
6 }1 Q1 M& N j. ]HTML 书写规范... 5
) r- `& [+ p% {CSS 书写规范... 6
7 a: E, m, }$ n
图片制作规范... 6
2 T2 c, x5 z8 w
One More Thing J.. 7
: A3 y) K7 @6 p* Z4 v; f! S" v
附言... 7
( y- Z g6 \$ K
3 \% C( w2 P; q4 ~( j. m
+ R! [+ k$ K+ @* E( _/ |) j2 O! N# q, p: R: T; i6 Y y
默认模板文件构成
- v6 l/ U' `( m& M9 m6 i# g
默认模板文件地址在./upload/template/default/由以下一些文件(夹)构成:
! }* r/ ~/ F g
0 S( }9 Y2 L* p# F7 t+ ?5 ocommon/
7 n9 l" U5 |! A存放CSS 文件及各个公共文件
! ?# o4 |& S# y- c3 y. H9 n$ Q
3 y1 G2 d; g" e4 z9 H9 d0 eforum/
3 c$ p5 _% X/ P- g& U存放论坛相关文件,还有编辑器、导读、淘帖、统计等也在其中
* U3 Q+ ]: x( l: C* {1 P& U# H3 L# V: ` ^. x4 `' q8 l4 E
group/
& p% s1 t8 m- d0 b, J) V% q存放群组相关文件,部分功能依赖于论坛的模板文件,比如群组帖子
/ _/ G) M' Z" y: e1 l" k% v/ e) J' b3 P
home/
$ |5 D# \+ T$ \& g
存放广播、记录、日志、相册、道具、勋章、消息、好友、好友搜索、邀请、积分、收藏、动态、家园、个人资料、分享、任务、帖子、交易、悬赏、活动、投票、辩论等各种功能的文件,以space_ 开头的模板主要用来展示,以spacecp_ 开头的更多用在管理操作
+ q9 ~. d8 ~- a* z! f7 ~2 O4 K5 F3 @
w0 d3 |8 v0 O% B A K: ?member/
2 Z' I8 T1 X \' C, G' E
存放登录、注册、找回密码相关文件
& y- z$ e$ o4 C P
: t' ]3 H8 g# H. jmobile/
3 i& I0 x7 Z, R. Z7 P存放手机版的相关文件
( e- r1 |* z0 R/ c; s- S
2 u# O! N7 D+ A1 Mportal/
" a2 H9 L( [/ I+ p B: O. }存放门户相关文件,还有门户管理及 DIY 的一些东西
+ b$ ~0 f0 {" ^/ g3 m
+ @& w% w$ F/ y0 A9 _3 ~ranklist/
" q) Y& N9 U( ?1 X- C8 ] r9 y
存放排行榜相关文件,不过排行榜功能已经不再开发了
5 Y A* M" X; {. Z+ a
9 a6 P* @2 [! | y7 x
search/
5 X$ {" v8 i5 m4 [存放搜索相关的文件,从界面上来说属于一个基本独立的功能
6 n" _* [# b) [' `' d
& m) N- ?2 k6 ~( W" qstyle/
+ j) ?3 w. [0 [! D, y7 y; Q; Q
默认模板的另外五种配色
$ i/ H, W* S$ \; r
4 l+ @, z* o" q( i% l, Qtag/
! ?5 Y1 E0 s6 p8 v) J) T存放标签相关文件
9 |! o, l1 d# u$ D. k5 U
3 z y8 n f0 D5 [5 w) g+ Euserapp/
& C9 k' p& L; [3 y! C0 `
存放漫游应用相关的文件
/ o. f7 f3 Z4 u1 S
& |$ t/ ~1 a4 P% q4 ?: A
discus_style_default.xml
5 W7 _( C; V6 t J1 \配色文件,由后台生成,整个基调定下来后,在后台修改完导出后,一般不要再修改,因为如果修改了这个文件,站长在升级时需要重新导入才行
d7 O/ J9 L, {
, [! i& s3 ~* |4 S# a3 w# Q4 gpreview.jpg
/ t& {+ ]4 s" }* t; X9 m' \& @0 e用在后台的预览文件
/ B4 X! l' x- |! n, c2 M% d/ R
/ _! D% |! M) ~8 O Z' T+ V6 n1 K0 Tpreview_large.jpg
" S" ~- v8 U, F% ?8 M' J
用在后台的预览文件大图
: `! c+ x$ _& M3 L! X5 `默认模板的图片文件构成
; z- L x/ q9 P# J. g m
默认模板的图片文件地址在./upload/static/image/,其中admincp/存放的是后台的图片及CSS 文件,其余文件夹基本可以通过文件夹名字知道其用途。
1 X2 f, Z7 j5 l" O* ~. l) a; G3 f* a
! s7 [/ q& I* `' p' R6 d: t5 v./upload/static/其余几个文件夹大致用途如下:
* a2 x" T* ?. |' d$ r& f7 z
& z) j' Q, P! a! Zimage_big5/
, O/ ?1 A5 a/ t& a% K9 u# c/ S用于繁体中文 BIG5 码
& ~4 n5 a6 l1 k* }8 l2 {' P
& k# g: v1 L- u# K3 gjs/
9 `+ f6 l3 F' N; ?整站的Javascript文件都在这里
, [$ Y3 ^% y( ?
5 x/ g, V$ E( \( G5 V5 j
space/
' e7 F9 {+ w, A/ ?个人空间的八套风格文件,包括图片、CSS 文件都在这里
7 W; c( H- K6 a4 p) f% J
# ~, `9 ^6 Y2 c+ itopic/
5 U+ w: k: ]9 P$ a* B门户用到的两个默认专题样式
, f: `9 R/ f% N4 h8 ^
默认模板修改原则
6 i/ |" K" l- X% q5 X
1、 首先应该考虑模块化、扩展性,因为同一个元素可能用在不同的页面的不同地方,如果太过于个性则可能冗余代码太多,另外使用 Discuz! 的站长有可能二次开发,所以在修改模板的时候,要尽可能多的考虑各种使用场景及可能性,这样才能平衡需求及易用性,以一种比较中庸的姿态来适应绝大多数站长的要求
+ m* S+ `+ R$ `3 U B2、 另外绝大多数第三方模板风格都是建立在默认模板的基础之上的,这就要求在修改默认模板的时候,要尽可能的考虑到方便这些风格制作者
8 R4 i7 o9 O$ R$ h
3、 还有就是 Discuz! 后台有许多开关,而且有些开关是相互关联相互影响的,所以每个页面开启或者关闭某个功能对页面布局的影响应该经常考虑,这要求首先要对后台的功能开关烂熟于心,建议每个功能自己都先开关一下试试
# l9 P: T3 `$ ?4、 Discuz! 的权限设计在模板中也有很多体现,因此在界面中会出现某些元素没有权限者看不到的情况,因此在修改某些地方的界面的时候,权限问题也要考虑进去
7 z" Z* V+ {/ Y& {4 H7 c' g0 ^
1 r% ~; M9 J+ a/ n/ K6 P. P* x# ~默认模板中的一些“陷阱”
. d, x6 x. S& o
1、 论坛的帖子 URL加不加参数&from=portal出来的效果是完全不一样的,不加就是默认的,加的话就会以门户的样式来展现帖子
# s) f7 ], e+ ?( q) B
2、 论坛的帖子和群组的帖子模板是公用的
$ e Y# p; H+ H. p
3、 论坛的分类信息相关页面,还有商品贴等的交易流程以及个人信用等页面隐藏的比较深,如果对这些不熟悉,建议先完整走一遍流程后再进行修改
; y6 e" S( t$ g( n ~4 a4、 对于顶部导航部分的修改,要考虑三个地方:搜索、个人空间以及论坛等其他通用页面,因为这三个地方用到了不同的头文件
t4 m) R; h$ {+ `1 V' r5、 对于广播、主题、日志、相册、记录、分享、留言板、个人资料等模板文件的修改,一定要注意,这些功能每个模板里都有四种组合情况的逻辑判断:“以SNS模块风格展示/以论坛模块风格展示、个性化DIY风格/论坛样式。”不同情况下展示出来的样式是完全不一样的,所以在制作的时候一定不要遗漏
/ R( S0 h0 D: J6 E& o
6、 在第5点提到的那些功能页面,URL 加不加参数&from=space显示的效果是完全不一样的,这个也需要非常小心
! c1 E6 }# F; k& n9 y! K7、 对于广播来说,mod=follow和mod=follow&uid=1&do=view显示的效果也是完全不一样的
' e6 C" ?* B9 c/ I$ m5 w1 t" X8、 验证码和验证问答,这是非常容易遗漏的一点,也是让人非常头疼的一点,因为许多页面本身很好看,但是为了验证码和验证问答,只能做一些折中的修改
3 z+ ?, \' D- K y ]0 _3 G% v需要兼容的浏览器列表
5 e7 [- F* ?, _9 Q
1、 市面上常见的一些浏览器,包括但不限于 IE9、IE8、IE7、IE6、Firefox、Chrome、Safari、Opera、360、Mathon等,一般都要兼容,不过一般情况下不需要做特别处理,因为只要 HTML 和 CSS 组织的比较好,就能比较巧妙的规避各个浏览器的不足之处。
% Q2 y1 o4 v/ d& L U. @2、 IE6/7 的优先级现在可以放在一个比较低的位置,就是说只要保证 IE6/7 下同样的功能不会乱掉就可以,因此在制作功能的时候,可以适当的使用 HTML5 和 CSS3,对于支持的浏览器可以显示出更炫的效果,对于不支持的,就以比较平淡的形式展示
+ M7 S1 _, y: Z# A1 n
HTML 书写规范1、 首先请遵守XHTML 的一些规范,比如小写、双引号、闭合等
9 _* e8 ?4 {# B5 G! \
2、 除此之外Discuz! 本身也有一些书写规范,主要集中在表单方面:
: f7 T! \8 R- F& s: Y% @
<label><inputtype="radio" name="" id="" class="pr"/>文字</label>
- h4 q2 h! o. J( U# {% `5 Q! @
8 ]' C+ @% m( _$ D$ ~4 R# w<label><inputtype="checkbox" name="" id=""class="pc" />文字</label>
. v5 y8 ]2 F6 u8 _8 e$ _: L V) J1 ?+ a9 d* G+ G) O. T' Y
除了属性要遵循type、name、id、class这种顺序外,还要:
5 A# [, f* l* d+ z5 ^( K
n 每个包含文字的 radio 和 checkbox(以下简称“框”)应用<label>包含起来(不兼容 IE6,但是节省许多代码)
, o! Y- L) j! I9 |# M- r! I$ Yn 每个框应写上相应的 class="pr" 或 class="pc"
: A/ T. K2 L- wn <input />与文字之间不要空格
! H: M7 s9 |5 `% w3 k3、 对于链接,要保证href为第一个属性
/ [' r' {+ R; ]' C) p4、 对于图片,应该有alt属性,哪怕为空的;对于已知尺寸固定的图片,还应该写上width、height数值,这样可以加快浏览器对整个页面的渲染
7 b" W! F3 X# q" W/ t/ L+ _# y5、 凡是有数字或者英文的地方,应该前后各空一个半角空格
2 R H, B+ j F% y K6、 对于类似 <div class=“a<!--{if …}-->…<!--{/if}-->”></div>这样写是不规范的,应该去掉“<!--”和“-->”,改为<div class=“a{if …} …{/if}”></div>
# \; z# z/ d, W6 v( k
7、 相应的 HTML 结构应该按照从属进行缩进,标准是一个或多个 Tab
! ~/ p1 C, q2 G" M- W
CSS 书写规范1、 在common.css及module.css文件里有具体的写作规范,请严格按照规范来书写,为了整个产品的规范性,建议先通读一遍
. V, D: i! W% d' Q0 q( ^ f2、 需要注意的是,CSS原始文件里有一些形如{HIGHLIGHTLINK}之类的变量,这些就是在后台界面管理里写入了一些提炼出来的通用样式,所以在书写的时候,能用到变量的就不要使用具体的值。比如有个地方需要高亮链接的颜色,那么就要这样写color: {HIGHLIGHTLINK};
" f6 d$ ?5 S% m
3、 对于CSS 命名规范,要求不能使用大写字母,以言简意赅为主,同时尽量抽象,尽量避免类似 .blue { color: blue; } 之类的命名,而是写成比如.highlight {color: blue; },尽量考虑到扩展重用
, }: ~7 P6 u* R( [* h! [
4、 尽量避免使用 CSS Hack,Discuz! 会自动判断 IE 浏览器版本,自动给<html>添加.ie_all, .ie6, .ie7, .ie8, .ie9等 class,所以需要针对这些浏览器进行 BUG 修正时,可以写成.ie_all .foo { ... } .ie6 .foo { ...}等
: o2 Q/ M9 c( m W$ T$ J
图片制作规范1、 为了保证较少的 HTTP 请求数,所以图片导出时要尽量将多张图片(常用于图标)合并为一张图片,也就是常说的 CSS 精灵。但是要把握一个度,比如站长在制作风格时经常会替换掉的图片,就一般不要合并,这个需要具体问题具体分析
2 G9 v8 w$ j$ J: W
2、 为了保证耗费较小的流量,图片导出时以 8 位 PNG为主,GIF和 JPG为辅,具体文件格式可以根据图片色彩构成来决定。对于透明图标,则一般要导出为 8 位索引色透明 PNG,以保证 IE6 下不出现灰块
) v l; h& T# X6 D% E9 R3、 为了保证占用较小的客户端内存,对于需要repeat 的背景图片,尺寸要控制在一定范围内,不能太小,也不能太大。绝对不要使用 1×1 等这种 repeat-x/y 的背景图片,会非常耗费内存
. ^3 D) k% F; W, B4 k; \4、 Discuz! 前台图片文件的命名目前没有一个统一的规范,一般都是以图片所处的功能区来命名的,不过希望能在将来能逐渐改变这种命名方式,统一为以其形态来命名。比如背景图片都以 bg_*.png 等形式命名,小图标都以 ico_*.png等形式命名,按钮都以 btn_*.png 等形式命名等(Discuz! 后台的图片文件就是采用采用此种命名方式),这种命名方式常用在游戏开发中,好处就是可以在大量的图片文件中迅速找到要找的图片,而且能知道其大致的用途
# F/ N) U- o7 j9 TOne More Thing J在 Discuz! 这个品牌出现的地方,首字母“D”一定要大写,“iscuz”要小写,还有一点很重要的是不要忘记了最后一个“!”,只有这样才是完整的Discuz!
+ L- M( |7 n! \6 ~5 ^% _
附言更多详尽的文档请参考 SVNdocuments 目录下的一些文档。