CSS的ID选择器的唯一性具体范围是什么?
知道ID选择器具有唯一性,是表示在整站中只能定义一次,还是只是一个页面中定义一次? 比如像站点LOGO或者导航栏都是用ID来定义的,整站不止一个页面,首页用ID了,内页的LOGO和导航栏还能用ID定义吗?还是要用CLASS?
知道ID选择器具有唯一性,是表示在整站中只能定义一次,还是只是一个页面中定义一次? 比如像站点LOGO或者导航栏都是用ID来定义的,整站不止一个页面,首页用ID了,内页的LOGO和导航栏还能用ID定义吗?还是要用CLASS?
答案:ID,在这个页面中,只能用 一次 ,但如果你有N个页面,那么这些页面中可以包含这ID
二问,只要ID不重复,写ID或CLASS均可:
正确写法:
<div>
<a href="#" id="logo"><span class="innerlogo"></span></a>
<div id="tab"><div class="innertab"></div></div>
</div>
或:
<div>
<a href="#" id="logo"><span class="logo"></span></a>
<div id="tab"><div class="tab"></div></div>
</div>
或
<div>
<a href="#" id="logo"><span id="innerlogo"></span></a>
<div id="tab"><div id="innertab"></div></div>
</div>
错误写法(ID被使用了两次):
<div>
<a href="#" id="logo"><span id="logo"></span></a>
<div id="tab"><div id="tab"></div></div>
</div>
其他:典型的书看太多没有实践过,你ID起不同名不就得了。比如导航的ID叫shouye_daohang,LOGO的ID叫Yemian_LOGO 如果ID,和CLASS在不与JS共同使用的时候,而仅仅是在CSS中使用,是没有什么区别的。 但是,在具体的使用上,HTML中的ID的唯一性还体验在: ID只能用1个 一、ID与CLASS的使用原则
据说W3C对于ID与CLASS的设定是ID具有唯一性,CLASS具有普遍性。所以我们这里的使用原则也是依据这一特性建立的。
ID是不能重复的,所以在XHTML的结构中,大结构一定是用ID。比如标志、导航、主体内容、版权。这些呢接我自己制定的规范命名为#logo , #nav , #content , #copyright 这些是雷打不动的命名。有人说布局排版用ID,配色背景用CLASS,其实这是不正确的,ID与布局排版没有直接关系,CLASS与配色也不是对等的。有人呢为了麻烦全都用ID或是全都用CLASS,全都用CLASS呢还有可理解,全都用ID就不正常了,这有悖ID唯一性。如果每个ID都不一样,那非累死不可。我通过实践总结的使用原则是:ID需要具有唯一性,并且尽量在外围使用。而CLASS具有可重复性,并且尽量在结构内部使用。这样做的好处是有利于网站代码的后期维护与修改,这样的做法就会让所有的CLASS都成为ID的子级或是孙级。
你可以有两个儿子但你能有两个爸爸吗,就是这个道理。在我们写CSS的时候可以写成这样 #father .child 尽量不要让Class包含ID,.father #child 如果写成这样显得有点可笑 。当然这也不是铁定的,特殊情况需要特殊对待嘛。但是通常情况下这种形式的必要性不大。
以上就是ID与CLASS使用原则,归总起来一句话:ID是唯一的并是父级的,CLASS是可以重复的并是子级的。
二、ID与CLASS的使用技巧
1、子级的命名的包含父命名中的部分为开头。这样方便在编写CSS时明确层次关系。
2、CLASS中的子级最好不用ID。当然特殊情况特殊对待。
3、CLASS的命名最好命名用大小写合用。例 .newMovie 这样的写法与第一条结合起来使用明确关系最合适。要需要注意的是IE以外的浏览器对于大小写是很敏感的。还有就是一定要以字母开头。
其实上面讲的都是一些大家都明白的内容,只是我捡了个漏先写下来算是一个总结。希望大家对于ID与CLASS的使用提出自己的新观点新思路。一起总结出最适合也最有效率的规范来。
上一个:div+css框架下如何实现页面的部分刷新? 利用ajax 不用iframe,你说的第二种方法可以给个实例吗?
下一个:css访问后的链接字体加粗的代码怎么写?