在样式表定义一个样式的时候,可以定义id也可以定义class。1、在CSS文件里书写时,ID加前缀"#";CLASS用"."2、id一个页面只可以使用一次;class可以多次引用。3、ID是一个标签,用于区分不同的结构和内容,就象名字,如果一个屋子有2个人同名,就会出现混淆;class是一个样式,可以套在任何结构和内容上,就象一件衣服;4、从概念上说就是不一样的:id是先找到结构/内容,再给它定义样式;class是先定义好一种样式,再套给多个结构/内容。目前的浏览器还都允许用多个相同ID,一般情况下也能正常显示,不过当你需要用JavaScript通过id来控制div时就会出现错误。

附详文:定义格式:

另外,形如id="aaa"定义的,在css中是这样设置其样式的:

#aaa{ 样式列表 }

而以class="bbb"形式定义的,在css中应该这样设置其样式:

.bbb{ 样式列表 }

(注意前面有一个点) 

用途:

 class元素分2种,关 联的和独 立的. 关联的用于html的相关tag的,比如

h1.redone{color:red}

<h1 class= redone> 字体为红色的 <h1>

<h1> 字体是黑色的 <h1>

独 立的元素可以用于所有的html元素的,比如

.classname {property:value}

id元素和独 立的class功能相似,区别是id 是唯一的而且对于javascript操作html 元素有帮助,

#idname {property: value}

概念定义:

id是元素的名称,可以供js或其它脚本程序来访问该元素对象,而class是该元素的css类名。

id的值在整个当前网页中应该是唯一的,即某一个元素定义了id="aaa",那么这个网页中其它的元素的id就不能定义成aaa,而class则可以。

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的使用提出自己的新观点新思路。一起总结出最适合也最有效率的规范来。

若出现重复定义时,从优先级来看是:

Style > ID > Class > 缺省的Html元素

一个Class是用来根据用户定义的标准对一个或多个元素进行定义的。打个比较恰当的比方就是剧本:一个Class可以定义剧本中每个人物的故事线,你可以通过CSS,javascript等来使用这个类。因此你可以在一个页面上使用class="Frodo" ,class="Gandalf", class="Aragorn"来区分不同的故事线。还有一点非常重要的是你可以在一个文档中使用任意次数的Class。

至于 ID,通常用于定义页面上一个仅出现一次的标记。在对页面排版进行结构化布局时(比如说通常一个页面都是由一个页眉,一个报头< masthead>,一个内容区域和一个页脚等组成),一般使用ID比较理想,因为一个ID在一个文档中只能被使用一次。而这些元素在同一页面中很少会出现大于一次的情况。

归纳成一句话就是:Class可以反复使用而ID在一个页面中仅能被使用一次。有可能在很大部分浏览器中反复使用同一个ID不会出现问题,但在标准上这绝对是错误的使用,而且很可能导致某些浏览器的现实问题。

在实际应用的时候,Class可能对文字的排版等比较有用,而ID则对宏观布局和设计放置各种元素较有用

转载于:https://www.cnblogs.com/lzhitian/archive/2012/11/25/2787212.html

【转】在CSS中 ID与Class的区别?谢谢相关推荐

  1. CSS中id选择器和class选择器

    CSS中对html元素的样式进行控制是通过CSS选择器来完成的,最常用的两种选择器为id选择器和class选择器. id选择器和class选择器介绍 id选择器:用来为标有特定id的html元素指定特 ...

  2. css实例 css中id/class 详解样式表(外部样式表 内部样式表 内联样式 7种基础选择器 多重样式优先级 错误理解)[第一天]

    文章目录 css实例 css中的id css中的class 样式表 外部样式表 内部样式表 内联样式 7种基础选择器 多重样式优先级 错误理解 css实例 CSS 规则由两个主要的部分构成:选择器,以 ...

  3. html代码id,浅谈html中id和name的区别实例代码

    浅谈html中id和name的区别实例代码 更新时间:2008年07月28日 23:00:55   作者: 这个是form里面的name与id的区别 我们可以通过一段代码来分析一下其中的微妙差别: 在 ...

  4. css里dotted,CSS中dashed和dotted的区别有哪些

    对于刚刚接触css的朋友们来说都会分不清dashed和dotted,那么你知道CSS中dashed和dotted的区别有哪些吗?那么针对这个问题爱站小编就为大家接受CSS中dashed和dotted的 ...

  5. CSS中background与background-image的区别

    CSS中background与background-image的区别 1.如果只是设置两张背景图不涉及CSS样式那么两者都可以使用 2.如果设置样式那就只能用background,如 以下是不适用ba ...

  6. CSS中绝对定位和相对定位的区别及作用

    CSS中绝对定位和相对定位的区别及作用 针对定位的区别及使用我整理一些方法 一.绝对定位 二.相对定位 三.绝对定位与相对定位的区别 四.绝对定位与相对定位的使用 结语 针对定位的区别及使用我整理一些 ...

  7. 外部引用CSS中 link与@import的区别

    这两天刚写完XHTML加载CSS的几种方式,其中外部引用CSS分为两种方式link和@import. 本质上,这两种方式都是为了加载CSS文件,但还是存在着细微的差别. 差别1:老祖宗的差别.link ...

  8. CSS中margin和padding的区别

    padding.margin都是边距的含义,关键问题得明白是什么相对什么的边距.padding是控件的内容相对控件的边缘的边距,margin是控件边缘相对父空间的边距. 在CSS中margin是指从自 ...

  9. CSS中id选择器失效,代码看起来没问题

    我的处女作<Canvas系列教程>在我的Github上正在连载更新,希望能得到您的关注和支持,让我有更多的动力进行创作. 教程介绍.教程目录等能在README里查阅. 传送门:https: ...

最新文章

  1. Google的其他用法
  2. Python把函数作为参数传入的高阶编程方法
  3. OpenCV--实现图像滑动窗口截取子图操作
  4. 程序员,建立你的商业意识
  5. WebApi2官网学习记录---Media Formatters
  6. 《TensorFlow技术解析与实战》学习笔记2
  7. python解释器源码下载_深入 Python 解释器源码,我终于搞明白了字符串驻留的原理!...
  8. python制作ppt_如何利用Excel与Python制作PPT
  9. 网络ip段计算,网络地址计算,广播地址计算,主机号计算规则
  10. 变色龙引导安装黑苹果 遇到的问题的解决办法
  11. python获取工作目录路径为C:\Users\用户名\AppData\Local\Temp...解决方案
  12. win10创建新的计算机用户名和密码,win10电脑怎么新建用户?高手教你在win10新建用户的方法...
  13. hdu5956, The Elder (树型dp, 斜率优化)
  14. 个人怎么开发APP?APP开发全流程解析!
  15. 2022国赛数学建模A题B题C题资料思路汇总(含有代码可运行)
  16. 随机失活 dropout直观理解
  17. 第三章 - 有穷自动机与词法分析(一)
  18. 面试经验|2月最新映客直播一面+二面
  19. HTTPS升级配合HSTS打造顶级安全网站
  20. HTML5方向键控制会奔跑的马里奥大叔

热门文章

  1. 使用Phar来打包发布PHP程序
  2. IDEA新建spring boot项目没有Spring Initializr选项
  3. [Ljava.lang.String和java.lang.String区别
  4. How to become the truely yourself?
  5. 嘿,是时候重新认识下海淘了
  6. Pinterest 首位产品经理:爆发式增长背后的 5 大经验总结
  7. 为什么说“按月订购”和“无人货架”本质上是一样的?
  8. 产品经理心中都住着一个段子手?看看他们如何相爱相撕的...
  9. 【pmcaff】产品经理必知改善用户体验的基本方法
  10. Python语言规范