找回密码
 加入怎通
查看: 882|回复: 1

[站长八卦] CSS的十个常用技巧

[复制链接]
TONY 发表于 2011-11-29 08:28:15 | 显示全部楼层 |阅读模式
1.CSS 字体属性简写规则' P( @. B$ ?5 A% v, B
一般用 CSS 设定字体属性是这样做的:
& ~' Z) l1 R5 Afont-weight:bold;font-style:italic;font-varient:small-caps;font-size:1em;line-height:1.5em;font-family:verdana,sans-serif;% F" V  W0 u9 k3 e: C% l9 ?
但也可以把它们全部写到一行上去:
3 Q1 E- p9 N8 G7 G/ G4 q! q# vfont: bold italic small-caps 1em/1.5em verdana,sans-serif;* `, L( H. U  V8 R
真不错!只有一点要提醒的:这种简写方法只有在同时指定 font-size 和 font-family 属性时才起作用。而且,如果你没有设定 font-weight, font-style, 以及 font-varient ,他们会使用缺省值,这点要记上。
0 W0 p) G+ ~8 i: I" p9 r2. 同时使用两个类
5 i0 k1 q0 n2 M5 [一般只能给一个元素设定一个类(Class),但这并不意味着不能用两个。事实上,你可以这样:
9 e( b" X" _- a% b, o0 X9 Q! n<p class="text side">...</p>
# Y' y. h! P: Y- g- w; k6 k同时给 P 元素两个类,中间用空格格开,这样所有 text 和 side 两个类的属性都会加到 P 元素上来。如果它们两个类中的属性有冲突的话,后设置的起作用,即在 CSS 文件中放在后面的类的属性起作用。
& s" J" m' R8 O5 N4 k补充:对于一个ID,不能这样写 <p id="text side">...</p>! E  F) x- f9 H
3. CSS border 的缺省值
' w0 ?+ F: l6 {. N. J) S* k- ~通常可以设定边界的颜色,宽度和风格,如:border: 3px solid #000
9 m* ^, d8 R( w# ?/ ^3 b这位把边界显示成3像素宽,黑色,实线。但实际上这里只需要指定风格即可。
" ?1 Q$ l1 O0 w/ j! R; D如果只指定了风格,其他属性就会使用缺省值。一般地,Border 的宽度缺省是 medium,一般等于3到4个像素;缺省的颜色是其中文字的颜色。如果这个值正好合适的话,就不用设那么多了。6 o  _4 Z* [$ p2 H$ K5 c
4. CSS 用于文档打印
4 [0 P) C9 ^$ X( K6 k/ [3 \许多网站上都有一个针对打印的版本,但实际上这并不需要,因为可以用 CSS 来设定打印风格。也就是说,可以为页面指定两个 CSS 文件,一个用于屏幕显示,一个用于打印:. W) O7 k6 g2 j7 A  L
<link type="text/css" rel="stylesheet" href="stylesheet.css" media="screen" /><link type="text/css" rel="stylesheet" href="printstyle.css" media="print" />
+ B. {9 [! K2 b6 b第1行就是显示,第2行是打印,注意其中的 media 属性。
$ S: U! U# w- m: W, v但应该在打印 CSS 中写什么东西呢?你可以按设计普通 CSS 的方法来设定它。设计的同时就可以把这个 CSS 设成显示 CSS 来检查它的效果。也许你会使用 display: none 这个命令来关掉一些装饰图片,再关掉一些导航按钮。要想了解更多,可以看“打印差异”这一篇。5 d' h4 k% ?9 ^$ T) q
5. 图片替换技巧
. `# d6 G3 }) E& h2 W# f- O& _( L一般都建议用标准的 HTML 来显示文字,而不要使用图片,这样不但快,也更具可读性。但如果你想用一些特殊字体时,就只能用图片了。
. R! K/ q( z2 v; w2 y6 c9 U2 V比如你想整个卖东西的图标,你就用了这个图片:
8 O' r( u& B" J<h1><img src="widget-image.gif" alt="Buy widgets" /></h1>1 ^6 Q$ b; O- I. r# R
这当然可以,但对搜索引擎来说,和正常文字相比,它们对 alt 里面的替换文字几乎没有兴趣这是因为许多设计者在这里放许多关键词来骗搜索引擎。所以方法应该是这样的:
6 [0 X- z7 G. i1 _4 E<h1>Buy widgets</h1>
+ _: ^) h8 Z. J0 ]但这样就没有特殊字体了。要想达到同样效果,可以这样设计 CSS:
: f' H" M3 @- f  ?9 H! hh1 { background: url(widget-image.gif) no-repeat; height: image height; text-indent: -2000px }
. E/ A1 o+ m5 f注意把 image height 换成真的图片的高度。这里,图片会当作背景显示出来,而真正的文字由于设定了 -2000 像素这个缩进,它们会出现在屏幕左边 2000 点的地方,就看不见了。但这对于关闭图片的人来说,可能全部看不到了,这点要注意。
0 U) ^1 y9 g3 l& x1 [3 N% L6. CSS box 模型的另一种调整技巧9 r% g1 q# q+ ^$ K
这个 Box 模型的调整主要是针对 IE6 之前的 IE 浏览器的,它们把边界宽度和空白都算在元素宽度上。比如:: Q) N" ^! d( K; C, s  h
#box { width: 100px; border: 5px; padding: 20px }3 u. A& j7 U6 j8 ^0 M) U# z' @4 |
这样调用它:, g% l. `9 c3 ]) H4 e6 N
<div id="box">...</div>
7 E" _8 ~6 e, q" S3 o; z( p这时盒子的全宽应该是 150 点,这在除 IE6 之前的 IE 浏览器之外的所有浏览器上都是正确的。但在 IE5 这样的浏览器上,它的全宽仍是 100 点。可以用以前人发明的 Box 调整方法来处理这种差异。: @/ F/ \/ ]# j. p% C
但用 CSS 也可以达到同样的目的,让它们显示效果一致。
3 A" y- ~; O8 w" @; b+ u#box { width: 150px }#box div { border: 5px; padding: 20px }
) t$ W( ?1 y: ^9 J- q! P这样调用:& d. }5 [. D# l+ P
<div id="box"><div>...</div></div>
9 ~' E1 R: b, S, E3 |* N这样,不管什么浏览器,宽度都是150点了。5 X- p& f/ N- m8 R+ }
7. 块元素居中对齐4 s# C! q5 i9 C. }# }  S7 N# H- S
如果想做个固定宽度的网页并且想让网页水平居中的话,通常是这样:
# S1 O, p& V+ n' I* y#content { width: 700px; margin: 0 auto }/ R9 J. u' ]# h/ {: ~$ w
你会使用 <div id="content"> 来围上所有元素。这很简单,但不够好,IE6 之前版本会显示不出这种效果。改 CSS 如下:/ R% }& v, c9 d. s+ U8 i
body { text-align: center }#content { text-align: left; width: 700px; margin: 0 auto }
) f0 f, Q9 v" d- J8 r' k这会把网页内容都居中,所以在 Content 中又加入了 text-align: left 。! b1 l- O$ I% B7 u! _
8. 用 CSS 来处理垂直对齐
$ w5 e8 P& c9 \7 @+ `垂直对齐用表格可以很方便地实现,设定表格单元 vertical-align: middle 就可以了。但对 CSS 来说这没用。如果你想设定一个导航条是2em高,而想让导航文字垂直居中的话,设定这个属性是没用的。/ h7 h( I9 V/ H; V! k6 ^" w8 }! f
CSS 方法是什么呢?对了,把这些文字的行高设为 2em:line-height: 2em ,这就可以了。# Q" A) ^( H7 T3 a3 {
9. CSS 在容器内定位7 F  a- z$ s! ~3 I) r
CSS 的一个好处是可以把一个元素任意定位,在一个容器内也可以。比如对这个容器:
7 H5 w+ [" _5 P6 N#container { position: relative }
2 \2 y' e, w& L, b5 V这样容器内所有的元素都会相对定位,可以这样用:
/ j1 S$ B1 R: I<div id="container"><div id="navigation">...</div></div>
" Q" _& {: h% ?& q; `* w如果想定位到距左30点,距上5点,可以这样:# n1 D' X( z7 t  H+ o/ ]! K
#navigation { position: absolute; left: 30px; top: 5px }0 x- C. ~+ K5 E: h
当然,你还可以这样:6 v+ x* L" L' v5 D
margin: 5px 0 0 30px
$ D# W. I2 ]4 L& k5 i注意4个数字的顺序是:上、右、下、左。当然,有时候定位的方法而不是边距的方法更好些。
# {% c4 R( H4 |2 s10. 直通到屏幕底部的背景色
9 j. K2 [! t* b  Z; M. A7 ?* C在垂直方向是进行控制是 CSS 所不能的。如果你想让导航栏和内容栏一样直通到页面底部,用表格是很方便的,但如果只用这样的 CSS:
' p2 @; c# `; ^8 @  e6 c" C#navigation { background: blue; width: 150px }/ t" j/ c) O* \
较短的导航条是不会直通到底部的,半路内容结束时它就结束了。该怎么办呢?
6 f1 m6 t" ^1 K不幸的是,只能采用欺骗的手段了,给这较短的一栏加上个背景图,宽度和栏宽一样,并让它的颜色和设定的背景色一样。# `3 g  s* Z- [) K* h  Q- E
body { background: url(blue-image.gif) 0 0 repeat-y }
7 _% B8 B; P$ _9 c2 j此时不能用 em 做单位,因为那样的话,一旦读者改变了字体大小,这个花招就会露馅,只能使用 px。* `1 ?0 S; i; [) T* S% B% ^
原文整理来源:zoomla!逐浪CMS
回复

使用道具 举报

紫星墙绘 发表于 2026-02-21 15:51:23 | 显示全部楼层
蹲了这么久,终于看到有价值的讨论,支持一下!
回复 支持 反对

使用道具 举报

    您需要登录后才可以回帖 登录 | 加入怎通

    本版积分规则

    QQ|手机版|小黑屋|网站地图|真牛社区 ( 苏ICP备2023040716号-2 )

    GMT+8, 2026-3-26 04:04 , Processed in 0.052997 second(s), 24 queries , Gzip On.

    免责声明:本站信息来自互联网,本站不对其内容真实性负责,如有侵权等情况请联系420897364#qq.com(把#换成@)删除。

    Powered by Discuz! X3.5

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