博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

CSS技巧补遗二十四则

Posted on 2008-10-14 12:51  linFen  阅读(208)  评论(0编辑  收藏  举报
在CSS网页布局开发中,会有很多小技巧,新手朋友往往对此很不熟悉。在某一两个小问题上,或许纠缠很长时间才能搞明白,虽然在52CSS.com的文档中,多次提及过这方面的内容,但依然有很多朋友在这些问题上犯错。我们今天看看这些CSS技巧,认真读一读,或许您并不能完全理解,您可以在52CSS.com进行搜索,扩展您所想要得到的知识,相信您会有很多收获!

  一、ul标签在Mozilla中默认是有padding值的,而在IE中只有margin有值。
  二、同一个的class选择符可以在一个文档中重复出现,而id选择符却只能出现一次。对一个标签同时使用class和id进行CSS定义,如果定义有重复,id选择符做的定义有效,是因为id的权重要比class大。
  三、一个兼容性调整(IE和Mozilla)的笨办法:
    初学可能会碰到这样一个情况:同样一个标签的属性在IE设置成A显示是正常的,而在Mozilla里必须要设成B才能正常显示,或者两个倒过来。
    临时解决方法:选择符{属性名:B !important;属性名:A} 或许有时候并没有效果。你可以在52CSS.com搜索更多的BUG解决方法。
  四、如果一组要嵌套的标签之间需要些间距的话,那就留给位于里面的标签的margin属性吧,而不要去定义位于外面的标签的padding
  五、li标签前面的图标推荐使用background-image,而不是list-style-image。
  六、IE分不清继承关系和父子关系的差别,全部都是继承关系。
  七、在给你的标签疯狂加选择符的时候,别忘了在CSS里给选择符加上注释。等你以后修改你的CSS的时候就知道为什么要这么做了。另外提醒您,不要太疯狂了。
  八、如果你给一个标签设置了一个深色调的背景图片和亮色调的文字效果。建议这个时候给你的标签再设置一个深色调的背景颜色。因为图片丢失了,也可以保持文字的可读性。
  九、定义链接的四种状态要注意先后顺序: Link Visited Hover Active
  十、与内容无关的图片请使用background。时刻记住表现与内容分离。
  十一、定义颜色可以缩写#8899FF=#89F
  十二、table在某些方面还是有用武之地的,在遇到内容为数据表格时,不要对它产生憎恨的心理。
  十三、<script>没有language这个属性,应该写成这样:<script type=”text/javascript”>
  十四、完美的单象素外框线表格(在IE5、IE6、IE7及FF1.0.4以上中均可通过测试)
    table{ border-collapse:collapse; }
    td{ border:#000 solid 1px; }
    您也可以参考:
    与表格边框有关的CSS语法
    http://www.52css.com/article.asp?id=394
    CSS去除表格td默认间距及制作1px细线表格
    http://www.52css.com/article.asp?id=593
    实现符合Web标准的细线表格
    http://www.52css.com/article.asp?id=676
  十五、margin取负值可以在标签使用绝对定位的时候起到相对定位的作用,在页面居中显示时,使用绝对定位的层不适合使用left:XXpx这个属性。把这个层放到一个要相对定位的标签旁,然后使用margin的负值是个好方法。
  十六、绝对定位时使用margin值定位可以达到相对于本身所在位置的定,这与top,left等属性相对与窗口边缘的定位不同。绝对定位的优势在于可以让其它元素忽略它的存在。
  十七、如果文字过长,则将过长的部分变成省略号显示:IE5,FF无效,但可以隐藏,IE6有效
    <DIV STYLE=”width:120px;height:50px;border:1px solid blue;overflow:hidden;text-overflow:ellipsis”>
    <NOBR>就是比如有一行文字,很长,表格内一行显示不下.</NOBR>
  十八、在IE中可能由于注释带来的文字重复问题时可以把注释改为:
    <!–[if !IE]>Put your commentary in here…<![endif]–>
  十九、如何用CSS调用外部字体
    语法:
    @font-face{font-family:name;src:url(url);sRules}
    取值:
    name:字体名称。任何可能的 font-family 属性的值
    url(url):使用绝对或相对 url 地址指定OpenType字体文件
    sRules:样式表定义
  二十、如何让一个表单中的文本框中的文字垂直居中?
    如果用行高与高度的组在FF中是没有效果的,办法就是定义上下补白就可以实现想想的效果了。
  二十一、定义A标签要注意的小问题:
    当我们定义a{color:red;}时,它代表了A的四种状态的样式,如果此时要定义一个鼠标放上的状态只要定义a:hover就可以了,其它三种状态就是A中所定义的样式。只定义了一个a:link时,一定要记得把其它三种状态定义出来!
  二十二、并不是所有样式都要简写:
    当样式表前定义了如p{padding:1px 2px 3px 4px}时,在后续工程中又增加了一个样式上补白5px,下补白6px。我们并不一定要写成p.style1{padding:5px 6px 3px 4px}。可以写成p.style1{padding-top:5px;padding-right:6px;},你可能会感觉这样写还不如原来那样好,但你想没想过,你的那种写法重复定义了样式,另外你可以不必去找原来的下补白与左补白的值是多少!如果以后前一个样式P变了话,你定义的p.style1的样式也要变。
  二十三、网站越大,CSS样式越多,开始做前,请做好充分的准备和策划,包括命名规则。页面区块划分,内部样式分类等。
  二十四、固定宽度汉字截断:overflow:hidden;text-overflow:ellipsis;white-space:nowrap;(不过只能处理文字在一行上的截断,不能处理多行。)(IE5以上)FF不能,它只隐藏。

  如果您有很多不明白的,没关系,记录下这些技巧,常来52CSS.com看看,您一定有所收获。您也可以在左侧的搜索框输入你感兴趣的内容进行搜索。欢迎您发表评论,补充CSS技巧。