1.CSS 字体属性简写规则1 y6 ]' ]0 j4 H, d. P
一般用 CSS 设定字体属性是这样做的:2 g8 x8 I k F
font-weight:bold;font-style:italic;font-varient:small-caps;font-size:1em;line-height:1.5em;font-family:verdana,sans-serif;
$ q) J# }0 K, B但也可以把它们全部写到一行上去:
7 G z0 W7 a. w' Sfont: bold italic small-caps 1em/1.5em verdana,sans-serif;7 `' I: p2 K$ H5 N; f% M- O
真不错!只有一点要提醒的:这种简写方法只有在同时指定 font-size 和 font-family 属性时才起作用。而且,如果你没有设定 font-weight, font-style, 以及 font-varient ,他们会使用缺省值,这点要记上。
) P R3 z# n; g0 @" t8 C2. 同时使用两个类: ` z9 G; N2 Q5 b5 ?: G0 H
一般只能给一个元素设定一个类(Class),但这并不意味着不能用两个。事实上,你可以这样:7 s2 N; V3 o: D3 }+ L7 m$ ~
<p class="text side">...</p>( s$ U& U0 T3 G* ^/ |; P
同时给 P 元素两个类,中间用空格格开,这样所有 text 和 side 两个类的属性都会加到 P 元素上来。如果它们两个类中的属性有冲突的话,后设置的起作用,即在 CSS 文件中放在后面的类的属性起作用。% h C: l6 @9 y9 B
补充:对于一个ID,不能这样写 <p id="text side">...</p> Z. }: z0 ~& K2 e
3. CSS border 的缺省值# [0 ?3 I. y) k" R) H' R) _
通常可以设定边界的颜色,宽度和风格,如:border: 3px solid #000
# j7 J: A& {$ ^7 y% P0 T1 G4 y这位把边界显示成3像素宽,黑色,实线。但实际上这里只需要指定风格即可。
F/ [5 J& v3 @5 r8 Z! S$ V如果只指定了风格,其他属性就会使用缺省值。一般地,Border 的宽度缺省是 medium,一般等于3到4个像素;缺省的颜色是其中文字的颜色。如果这个值正好合适的话,就不用设那么多了。
. n! t0 J1 _8 D4 o4. CSS 用于文档打印4 e& s% |, A- J2 K1 h. U' s% p
许多网站上都有一个针对打印的版本,但实际上这并不需要,因为可以用 CSS 来设定打印风格。也就是说,可以为页面指定两个 CSS 文件,一个用于屏幕显示,一个用于打印:
. ]3 M, }+ l8 p: t. i# C5 b# H<link type="text/css" rel="stylesheet" href="stylesheet.css" media="screen" /><link type="text/css" rel="stylesheet" href="printstyle.css" media="print" />( _% [9 ?4 x# Y, E; v! E
第1行就是显示,第2行是打印,注意其中的 media 属性。2 M/ }+ H$ v) d5 \" d
但应该在打印 CSS 中写什么东西呢?你可以按设计普通 CSS 的方法来设定它。设计的同时就可以把这个 CSS 设成显示 CSS 来检查它的效果。也许你会使用 display: none 这个命令来关掉一些装饰图片,再关掉一些导航按钮。要想了解更多,可以看“打印差异”这一篇。
% L, W4 t) \: ` V- M& E1 V8 f5. 图片替换技巧
O& ^7 s" Q, f: G. D一般都建议用标准的 HTML 来显示文字,而不要使用图片,这样不但快,也更具可读性。但如果你想用一些特殊字体时,就只能用图片了。
1 R* P4 l% d) x4 k' z# J3 c& X比如你想整个卖东西的图标,你就用了这个图片:) Y) K8 S* i8 o5 s
<h1><img src="widget-image.gif" alt="Buy widgets" /></h1>+ F( G6 d7 u; F; T, o3 L' G! J* V
这当然可以,但对搜索引擎来说,和正常文字相比,它们对 alt 里面的替换文字几乎没有兴趣这是因为许多设计者在这里放许多关键词来骗搜索引擎。所以方法应该是这样的:# D6 } R; f% t9 N& P2 A- n
<h1>Buy widgets</h1>
; I6 K( l& g" Z$ w/ {# U/ a但这样就没有特殊字体了。要想达到同样效果,可以这样设计 CSS:
1 O3 a8 _* k: o, c( [* ]- mh1 { background: url(widget-image.gif) no-repeat; height: image height; text-indent: -2000px }
+ q) @& ?, ?( s; _0 Z注意把 image height 换成真的图片的高度。这里,图片会当作背景显示出来,而真正的文字由于设定了 -2000 像素这个缩进,它们会出现在屏幕左边 2000 点的地方,就看不见了。但这对于关闭图片的人来说,可能全部看不到了,这点要注意。
) ? P& X% S7 j9 x+ B; A6. CSS box 模型的另一种调整技巧, k5 o2 @1 c8 a8 J0 w
这个 Box 模型的调整主要是针对 IE6 之前的 IE 浏览器的,它们把边界宽度和空白都算在元素宽度上。比如: }( w3 Z. f; ]2 B
#box { width: 100px; border: 5px; padding: 20px }0 H- B6 o( p5 ~
这样调用它:9 b5 F$ m7 M+ V0 C6 o0 a" c
<div id="box">...</div>
. O/ F5 v. G0 v& I& N# U% I( Z这时盒子的全宽应该是 150 点,这在除 IE6 之前的 IE 浏览器之外的所有浏览器上都是正确的。但在 IE5 这样的浏览器上,它的全宽仍是 100 点。可以用以前人发明的 Box 调整方法来处理这种差异。$ { L C/ y# f
但用 CSS 也可以达到同样的目的,让它们显示效果一致。
# s( y' Z2 g0 T: P#box { width: 150px }#box div { border: 5px; padding: 20px }- b; [0 V7 u. p' G) o; {
这样调用:
# O$ K0 i5 j' T. s- Z( @5 t/ U/ L<div id="box"><div>...</div></div>
" x) ?* R, p* y! l% ?& T这样,不管什么浏览器,宽度都是150点了。
& @. ?0 S, W( O; B" G, ?7. 块元素居中对齐
6 @+ ]4 T" ]/ D9 Z& y7 u, r如果想做个固定宽度的网页并且想让网页水平居中的话,通常是这样:
* _ ~$ m* x l; f1 L) l3 t#content { width: 700px; margin: 0 auto }9 L0 q1 l& `) i
你会使用 <div id="content"> 来围上所有元素。这很简单,但不够好,IE6 之前版本会显示不出这种效果。改 CSS 如下:# O/ N) }. M) e$ g$ ]8 A: a' f
body { text-align: center }#content { text-align: left; width: 700px; margin: 0 auto } |4 m7 m8 K, I
这会把网页内容都居中,所以在 Content 中又加入了 text-align: left 。( q# T4 N& o$ C/ Z
8. 用 CSS 来处理垂直对齐$ `, c2 ^2 Q4 T9 _4 G; V1 L, O. {. }
垂直对齐用表格可以很方便地实现,设定表格单元 vertical-align: middle 就可以了。但对 CSS 来说这没用。如果你想设定一个导航条是2em高,而想让导航文字垂直居中的话,设定这个属性是没用的。
9 s/ j% @2 Q! V+ LCSS 方法是什么呢?对了,把这些文字的行高设为 2em:line-height: 2em ,这就可以了。
4 f+ R8 P5 B( w& z! W$ ?9. CSS 在容器内定位
; U0 Q' ~: v7 M" ]+ f" g9 o: n; oCSS 的一个好处是可以把一个元素任意定位,在一个容器内也可以。比如对这个容器:* c, Q0 U% Z, b$ t- D
#container { position: relative }
' ?4 p8 W- w! I这样容器内所有的元素都会相对定位,可以这样用:
! r1 _0 M) g. V# E. |% g+ e% }6 A& a<div id="container"><div id="navigation">...</div></div>
2 t$ D% {' a) k* \) Z8 c; m如果想定位到距左30点,距上5点,可以这样:
7 F$ @9 E) @/ o#navigation { position: absolute; left: 30px; top: 5px }
; i( j* y W( I$ C! m1 m4 }当然,你还可以这样:
( L8 X% d# ~7 M. ^margin: 5px 0 0 30px2 A% g+ F, J- ?8 s0 \3 N# l9 o0 ]
注意4个数字的顺序是:上、右、下、左。当然,有时候定位的方法而不是边距的方法更好些。
. [5 B1 S. o; @" a8 y, O: V10. 直通到屏幕底部的背景色+ X* c; L$ C' R* e ^6 W
在垂直方向是进行控制是 CSS 所不能的。如果你想让导航栏和内容栏一样直通到页面底部,用表格是很方便的,但如果只用这样的 CSS:5 x7 k- x8 U L% ?
#navigation { background: blue; width: 150px }8 S0 E2 q2 L9 K. D
较短的导航条是不会直通到底部的,半路内容结束时它就结束了。该怎么办呢?
% s* Y1 b3 B5 q9 P* n* T不幸的是,只能采用欺骗的手段了,给这较短的一栏加上个背景图,宽度和栏宽一样,并让它的颜色和设定的背景色一样。
) L6 M2 @7 T; ^5 L1 Z8 c8 Mbody { background: url(blue-image.gif) 0 0 repeat-y }2 H8 m; c j: i0 i x4 Z# p
此时不能用 em 做单位,因为那样的话,一旦读者改变了字体大小,这个花招就会露馅,只能使用 px。7 Q1 l+ E- X. B( V0 g |4 _
原文整理来源:zoomla!逐浪CMS |