返回列表 发新帖

CSS使用小技巧

247.6k 14
阿凡达 发表于 2013-7-16 18:01:29|湖北 | 查看全部 阅读模式

! n7 \! B( }$ c- q' y$ K2 x% y  1.CSS字体属性简写规则一般用CSS设定字体属性是这样做的:
6 @. N4 I3 I8 s' i1 A6 y5 J  font-weight:bold;  Z6 ^4 Q5 w; w, w9 c
  font-style:italic;; p' M7 q/ ?$ z
  font-varient:small-caps;# Y) [+ e) u) x8 q, A  ]+ [
  font-size:1em;
: v: |  l( O0 i4 g  line-height:1.5em;7 {( p! `" Q: d4 n
  font-family:verdana,sans-serif;4 K9 Z2 o7 l7 x- G
  但也可以把它们全部写到一行上去:
( I  V4 w/ V6 l9 I) c3 w) [  font: bold italic small-caps 1em/1.5em verdana,sans-serif;
' z7 z4 E1 u( y8 ^# K  只有一点要提醒的:这种简写方法只有在同时指定font-size和font-family属性时才起作用。而且,如果你没有设定font-weight, font-style, 以及 font-varient ,他们会使用缺省值,这点要记上。" o2 \5 n2 \0 x5 d# V% H/ {7 d+ m
  2. 同时使用两个类
" Y/ n8 Z" x4 s; v7 {% w& m' \+ @9 j  一般只能给一个元素设定一个类(Class),但这并不意味着不能用两个。事实上,你可以这样:% n3 \+ E& [9 a7 E  m* ^" ~; R: Z! ]9 ]
  : |2 c$ P, `3 A& Z* ]1 x6 J+ Q% R
1 q( P' Y7 k- u$ ?
3 m: ]  [" j' n8 @6 S5 i7 ?
  同时给P元素两个类,中间用空格格开,这样所有text和side两个类的属性都会加到P元素上来。如果它们两个类中的属性有冲突的话,后设置的起作用,即在CSS文件中放在后面的类的属性起作用。+ t! }7 o8 q! q- O4 a
  补充:对于一个ID,不能这样写
  ?" d1 O) \; G( v; H2 l
+ s( i8 j& r5 S2 F0 q7 j+ n也不能这样写
' e. W+ ]0 H& K: j" I  \5 u4 x* k- }
, G/ g, p4 J8 ?2 g! y9 ~9 D( w4 R  3. CSS border的缺省值# O4 E& S& S. f8 T" I/ f7 n
  通常可以设定边界的颜色,宽度和风格,如:4 J- u4 |1 `' d7 k) d1 V3 G
  border: 3px solid #000
2 X, r8 Z8 ]) [5 X% U  这位把边界显示成3像素宽,黑色,实线。但实际上这里只需要指定风格即可。
; B' ~$ q' ]/ B1 i! F  如果只指定了风格,其他属性就会使用缺省值。一般地,Border的宽度缺省是medium,一般等于3到4个像素;缺省的颜色是其中文字的颜色。如果这个值正好合适的话,就不用设那么多了。' d0 F; o3 Z2 c/ ]: y. _2 {2 {
  4. CSS用于文档打印6 O" z% n& W' i& ?' h: m
  许多网站上都有一个针对打印的版本,但实际上这并不需要,因为可以用CSS来设定打印风格。
0 S* V$ Q' p  J. P/ W4 `  也就是说,可以为页面指定两个CSS文件,一个用于屏幕显示,一个用于打印:, z; L/ ^1 B& j( l4 a& ^- N# r
  ! y+ G! |% D: ?/ H$ E! j( y
  0 f: z2 |4 v8 G# A: R$ H
  第1行就是显示,第2行是打印,注意其中的media属性。
& e/ L/ k7 y- u  但应该在打印CSS中写什么东西呢?你可以按设计普通CSS的方法来设定它。设计的同时就可以把这个CSS设成显示CSS来检查它的效果。也许你会使用 display: none 这个命令来关掉一些装饰图片,再关掉一些导航按钮。要想了解更多,可以看“打印差异”这一篇。
" P7 i1 @  F5 ~9 v* R% T  5. 图片替换技巧& i( j) d8 C- W7 m9 c- ]
  一般都建议用标准的HTML来显示文字,而不要使用图片,这样不但快,也更具可读性。但如果你想用一些特殊字体时,就只能用图片了。- d. d- g1 z. T% J! p
  比如你想整个卖东西的图标,你就用了这个图片:
* H( F3 h& q& U7 h' V  : v6 L+ ~9 D9 h6 B' E0 h* X* U

2 B4 i- ]' @. ^, Z4 V5 U4 T5 U   m# z+ e# N; G) d& l0 ?
  这当然可以,但对搜索引擎来说,和正常文字相比,它们对alt里面的替换文字几乎没有兴趣这是因为许多设计者在这里放许多关键词来骗搜索引擎。所以方法应该是这样的:
: M/ Y4 Y) W4 c  T  
  e1 T$ E( ^- o  a2 TBuy widgets, A, Q8 u* T  @. e- O7 _
; d) M5 B# t" Z
  但这样就没有特殊字体了。要想达到同样效果,可以这样设计CSS:
/ n5 N6 u- g: l( w6 @( z) L7 M  h1 { background: url(widget-image.gif) no-repeat; height: image height text-indent: -2000px }
: M7 N* r2 R+ I5 n, }0 Z5 g  注意把image height换成真的图片的高度。这里,图片会当作背景显示出来,而真正的文字由于设定了-2000像素这个缩进,它们会出现在屏幕左边2000点的地方,就看不见了。但这对于关闭图片的人来说,可能全部看不到了,这点要注意。
9 s9 q, o8 Y: g5 Q  6. CSS box模型的另一种调整技巧
4 w. f3 }( u! H2 T4 n  这个Box模型的调整主要是针对IE6之前的IE浏览器的,它们把边界宽度和空白都算在元素宽度上。比如:- \5 j( ~+ J+ ?
  #box { width: 100px; border: 5px; padding: 20px }3 f# Q1 H+ q% {0 M3 S
  这样调用它:" y/ m9 M/ |: ]/ P1 z( B
  " `  i% A3 }7 ^& q0 R
% b3 L6 Q) g5 ]$ D1 _" R( }6 }

, S/ u' p) |. Y& P+ i  这时盒子的全宽应该是150点,这在除IE6之前的IE浏览器之外的所有浏览器上都是正确的。但在IE5这样的浏览器上,它的全宽仍是100点。可以用以前人发明的Box调整方法来处理这种差异。
, O4 M& `$ R' u2 h; j. _  但用CSS也可以达到同样的目的,让它们显示效果一致。& G" y) g; ]( T' j
  #box { width: 150px } #box div { border: 5px; padding: 20px }
# a# J; ]3 K  l' ^  这样调用:. N: {! f% ^- q( U3 @' `
  : D5 N, d! Q3 z/ ?% t

; Q/ F1 ?" C. n, q$ ~ 4 N$ U, f' ^& O  t( Q
  这样,不管什么浏览器,宽度都是150点了。
9 T4 d( s" ~2 v  7. 块元素居中对齐
7 T8 [* c. N" \' E  如果想做个固定宽度的网页并且想让网页水平居中的话,通常是这样:
0 Z% K% l* P$ E  #content { width: 700px; margin: 0 auto }
+ {; `$ }  Q- |$ C9 K5 n. K# U8 I8 F  你会使用
8 N+ q3 [: d/ m" K% V- p  A来围上所有元素。这很简单,但不够好,IE6之前版本会显示不出这种效果。改CSS如下:
" }  ?5 d. E2 D
# S$ E  t# M  ?5 s  body { text-align: center } #content { text-align: left; width: 700px; margin: 0 auto }
- z* I# o# ~% z* G  这会把网页内容都居中,所以在Content中又加入了:text-align: left 。
2 Y) p5 l5 A6 p, Y: Y, n  8. 用CSS来处理垂直对齐4 S( L3 j6 ], j& ~
  垂直对齐用表格可以很方便地实现,设定表格单元 vertical-align: middle 就可以了。但对CSS来说这没用。如果你想设定一个导航条是2em高,而想让导航文字垂直居中的话,设定这个属性是没用的。( C4 B8 |, M( _: s. i$ s4 p
  CSS方法是什么呢?对了,把这些文字的行高设为 2em:line-height: 2em ,这就可以了。1 T2 [+ s8 H4 Y5 X, y
  9. CSS在容器内定位
0 a0 w5 q& b9 }$ G# x/ R) P0 h- Q  CSS的一个好处是可以把一个元素任意定位,在一个容器内也可以。比如对这个容器:2 U) k; U4 t! X9 f/ ], Z8 R
  #container { position: relative }
- N1 }1 W9 S. g0 a+ v  这样容器内所有的元素都会相对定位,可以这样用:
# k0 y, @; i0 D  
) c7 ]4 S* y5 g+ g" ~1 o- X3 g+ Y' I! g4 k/ a6 }7 C

* B2 f4 x. q5 |8 W6 P8 o  如果想定位到距左30点,距上5点,可以这样:3 o3 w, K: H' g/ q. r1 T
  #navigation { position: absolute; left: 30px; top: 5px }
$ k8 ]3 r4 _$ d  当然,你还可以这样:
# ?' `  @; ?/ n2 \: H3 m  margin: 5px 0 0 30px0 j% w. n$ S. A, E
  注意4个数字的顺序是:上、右、下、左。当然,有时候定位的方法而不是边距的方法更好些。
1 I" \3 `: m3 k% Q" ^  10. 直通到屏幕底部的背景色
6 P+ [( t/ l7 t0 A6 V  在垂直方向是进行控制是CSS所不能的。如果你想让导航栏和内容栏一样直通到页面底部,用表格是很方便的,但如果只用这样的CSS:
8 w, \3 N2 [* I$ E, L  #navigation { background: blue; width: 150px }  i" ?: E0 Q3 N) W3 D. s
  较短的导航条是不会直通到底部的,半路内容结束时它就结束了。该怎么办呢?
# L' p; H& u# u" l6 f  不幸的是,只能采用欺骗的手段了,给这较短的一栏加上个背景图,宽度和栏宽一样,并让它的颜色和设定的背景色一样。6 H$ L7 I9 A) W; I& ]# {/ }6 ]
  body { background: url(blue-image.gif) 0 0 repeat-y }7 H% g# z/ {& H& ~3 d6 @( v
  此时不能用em做单位,因为那样的话,一旦读者改变了字体大小,这个花招就会露馅,只能使用px。
" r- ?, P3 @6 E7 U: s  w

回复|共 14 个

pangio Lv.8 发表于 2014-10-23 08:03:08|伊朗 | 查看全部
宝贝..你来了...
ffuip Lv.8 发表于 2014-10-23 08:22:44|美国 | 查看全部
晕 在我帖里面找偶像啊??
apgckwmm Lv.8 发表于 2014-10-23 08:34:57|哈萨克斯坦 | 查看全部
晕倒`````不要造我的谣言哦~~小心我打你pp~~嘿嘿~~~~
inhidgehila Lv.8 发表于 2014-10-23 08:58:23|美国 | 查看全部
因删贴不及时所产生的任何法律(书法,基本法,劳动法,婚姻法,输入法,国际法,今日说法,与台湾关系法及文中涉及或可能涉及以及未及之法,各地治安管理条例)纠纷或责任本人概不负责。
佚名 发表于 2015-6-2 14:54:51
苍天之下,厚土之上,竟有如此奇人异士、文人墨客!讥讽于谈笑间,笑骂于无形中,层次之高,境界之深,非我等所能匹及,偶像啊!
佚名 发表于 2015-6-2 15:01:04
命不能争,运可以造,弱者认命,强者抗命,能者求命,智者造命。
佚名 发表于 2015-6-2 15:02:47
我帮不了你
佚名 发表于 2015-6-2 15:21:01
我的我的 忘记了 呵呵
佚名 发表于 2015-6-2 15:21:36
综上所述,恳请各位官员请勿动用武装力量请勿跨村、跨镇、跨市、跨省、跨国、跨洲、跨星球、跨银河系追捕。确因不抓不足以平民愤,或不抓就领不到薪水养家户口的公职人员,建议携带工作证
wwdu926a 发表于 2017-4-11 10:55:50|加拿大 | 查看全部
你这样的表现,就只配这几个字:窝囊废
wwzcdenleclv 发表于 2017-4-11 10:58:13|美国 | 查看全部
系统居然怀疑我灌水,我身边又没有水龙头。哦…明白了,身上有一个……
gevaemaidovef 发表于 2017-4-11 10:59:13|英国 | 查看全部
这个得知互动技术交流论坛很不错
alapScady 发表于 2017-4-11 11:01:18|日本 | 查看全部
我在顶贴~!~
Acropozelan 发表于 2017-4-11 11:01:36|委内瑞拉 | 查看全部
呵呵 放心 如我算错 你以后来砸我的帖子 呵呵

回复

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

本版积分规则

得知互动是一个融创意、设计、开发、营销、生活、互联网于一体的专业交流分享平台。
Copyright © 2026 站长技术交流论坛|互联网技术交流平台|Ai技术交流平台 版权所有 All Rights Reserved. Powered by Discuz! X5.0 鄂ICP备15006301号-5|鄂公网安备 42018502006730号
关灯 在本版发帖 扫一扫添加QQ客服 返回顶部
快速回复 返回顶部 返回列表