id一个页面只可以使用一次,class可以多次引用。
我在页面中用了多个相同id在浏览中显示也正常,id和class好象没什么区别,似乎多个相同id对页面也有什么影响嘛~
但是当你需要用JavaScript或其他脚本通过id来控制这个Box,那就会出现错误。
且页面存在多个相同的ID不能通过W3的校验。
id是一个标签,用于区分不同的结构和内容,就象你的名字,如果一个屋子有2个人同名,就会出现混淆;
class是一个样式,可以套在任何结构和内容上,就象一件衣服;
概念上说就是不一样的:
id是先找到结构/内容,再给它定义样式;class是先定义好一种样式,再套给多个结构/内容。
也就是说建议大家在写XHML+CSS时如果是维一的结构定位的就用id,否则就用class吧(这样让出非结构定位的div块的id让程序员自己定义使用)
web标准希望大家用严格的习惯来写代码。
三、使用css缩写
使用缩写可以帮助减少你CSS文件的大小,更加容易阅读。
常用的css缩写的主要规则:
颜色
16进制的色彩值,如果每两位的值相同,可以缩写一半,例如:
#000000可以缩写为#000;#336699可以缩写为#369;
盒模型尺寸
1、通常有下面四种书写方法:
property:
value1;表示所有边都是一个值value1;
property:
value1value2;表示top和bottom的值是value1,right和left的值是value2property:
value1value2value3;表示top的值是value1,right和left的值是value2,bottom的值是value3
property:
value1value2value3value4;四个值依次表示top,right,bottom,leftCSS常用命名规范及写法详解第3页共16页
方便的记忆方法是顺时针,上右下左。
具体应用在margin和padding的例子如下:
margin:
1px02px5px;
边框(border)
2、边框的属性如下:
border-width:
1px;
border-style:
solid;(solid代表直线)
border-color:
#000;
可以缩写为一句:
border:
1pxsolid#000;
语法是border:
widthstylecolor;
3、背景(Backgrounds)
背景的属性如下:
background-color:
#f00;
background-image:
url(background.gif);(图片地址)
background-repeat:
no-repeat;(重复反复)
background-attachment:
fixed;(附件:
固定的)
background-position:
00;(背景位置)
可以缩写为一句:
background:
#f00url(background.gif)no-repeatfixed00;
语法是background:
colorimagerepeatattachmentposition;
你可以省略其中一个或多个属性值,如果省略,该属性值将用浏览器默认值,默认值为:
color:
transparent
image:
none
repeat:
repeat
attachment:
scroll
position:
0%0%
4、字体(fonts)
字体的属性如下:
font-style:
italic;
font-variant:
small-caps;
font-weight:
bold;
font-size:
1em;
line-height:
140%;
font-family:
"LucidaGrande",sans-serif;可以缩写为一句:
font:
italicsmall-capsbold1em/140%"LucidaGrande",sans-serif;
注意,如果你缩写字体定义,至少要定义font-size和font-family两个值。
5、列表(lists)
取消默认的圆点和序号可以这样写list-style:
none;list的属性如下:
list-style-type:
square;
list-style-position:
inside;
list-style-image:
url(image.gif);可以缩写为一句:
list-style:
squareinsideurl(image.gif);
四、明确定义单位,除非值为0
忘记定义尺寸的单位是CSS新手普遍的错误。
在HTML中你可以只写width=100,但是在CSS中,你必须给一个准确的单位,比如:
width:
100pxwidth:
100em。
只有两个例外情况可以不定义单位:
行高和0值。
除此以外,其他值都必须紧跟单位,注意,不要在数值和单位之间加空格。
CSS常用命名规范及写法详解第4页共16页
五、区分大小写
当在XHTML中使用CSS,CSS里定义的元素名称是区分大小写的。
为了避免这种错误,我建议所有的定义名称都采用小写。
class和id的值在HTML和XHTML中也是区分大小写的,如果你一定要大小写混合写,请仔细确认你在CSS的定义和XHTML里的标签是一致的。
六、取消class和id前的元素限定
当你写给一个元素定义class或者id,你可以省略前面的元素限定,因为ID在一个页面里是唯一的,class可以在页面中多次使用。
你限定某个元素毫无意义。
例如:
div#id1{}可以写成#id1{}
七、默认值
通常padding和margin的默认值为0,background-color的默认值是transparent。
但是在不同的浏览器默认值可能不同。
为避免冲突,可以在样式表一开始就先定义所有元素的margin和padding值都为0,象这样:
*{
padding:
0;
margin:
0
}
或者是针对某元素来定义:
body,ul,li,div,span{
padding:
0;
margin:
0
}
八、CSS的优先级
内联样式(inlinestyle)>ID选择符>类选择符(class),伪类(pseudo-class)和属性(attribute)选择符>类别(type),伪对象(pseudo-element)
解释:
*内联样式(inlinestyle):
元素的style属性,比如red;">
,其中的color: