解析css中的选择符命名

   原来命名可以这样的

  前一段时间,在某一站点看到了这样的内容:


  "这也可以?"是我对此的第一印象。不过,稍作调查知道了,这样写确实是有效的。此外,这个?_?的符号表情,看起来是不是相当有存在感?再看看搭配的css属性,display: none !important;即定义元素一定不显示,是不是也非常符合这个表情想要表达的意思?

  只要遵循css语法,就可以很好地应用这种不常见的命名。

  命名字符的规定

  英文单词的组合你一定很熟悉,例如.top_nav用来表示顶部导航,不仅用了合法的选择符,而且也很符合语义化的要求。

  另外,你应该也知道,选择符命名的开头字符,不可以是数字,例如.3-column不是合法的选择符。使用不合法的选择符的后果是,对应的css样式规则会因为选择符无法正确解析,而变为无效。

  事实上,css语法对于命名字符有更多的规定。以下是W3C关于命名标识符的说明中的内容:

  In CSS, identifiers (including element names, classes, and IDs in selectors) can contain only the characters [a-zA-Z0-9] and ISO 10646 characters U+00A0 and higher, plus the hyphen (-) and the underscore (_); they cannot start with a digit, two hyphens, or a hyphen followed by a digit. Identifiers can also contain escaped characters and any ISO 10646 character as a numeric code.

  意思是说,css中允许使用的命名字符,包括大小写英文字母、数字、连字符-、下划线_及其他ISO 10646字符集(等同于Unicode)中的字符。同时,起始字符部分不能是数字,或连续2个-,或1个-后接1个数字。此外,允许使用转义字符和任意ISO 10646字符的数字代码。

  经过测试,IE6对起始字符是下划线_和单个连字符-的情况,也会认定样式规则无效。

  字符转义

  可以看出,命名允许使用的字符其实是非常多的。但是,有一个地方需要注意,就是特殊字符。特殊字符是指在css语法中,被认定用来表示特定含义的字符(相当于编程语言中的关键字)。例如,...这样的class命名是不合法的,因为.是css选择符中表示class的字符,因此不允许直接用在命名中(...这位沉默着的class名你感觉如何?)。

  css中的特殊字符包含:!, ", #, $, %, &, ', (, ), *, +, ,, -, ., /, :, ;, <, =, >, ?, @, [, , ], ^,`, {, |, }, 和~。

  这个时候,想要在命名中也加入这些特殊字符,就要使用字符转义(character escape)。字符转义通过反斜杠实现,在css选择符中,你可以通过在特殊字符前加的方法,取消特殊字符的特定含义,使其可以正确地被用于命名。例如,特殊字符#就可以用#来表示。

  反斜杠的作用还不只如此。前面说到,任意ISO 10646字符都可以使用。按照ISO 10646的定义,所有的字符都可以用十六进制的代码来表示(尤其是一些不易直接输入的字符需要这样表示)。css语法中,以反斜杠开头,后接最多6位十六进制数字,即构成一个ISO 10646字符的代码。这和直接输入ISO 10646字符是一样的,但由于形式上是代码,因此是最可靠的。

  取消特殊字符的特定含义,除了前边的直接在前边加的写法外,还可以用ISO 10646代码。比如#也可以用23或者00023表示。请注意,如果代码不满6位(前面几位是0),一定要在末尾留一个空格,这才能组成一个正确的ISO 10646代码(这个空格是分隔标识用,算作代码的一部分,不会引发选择符中的特殊含义)。如果不想有这个空格,请使用完整的6位十六进制代码。

  比如,下面是一个合法的命名示例。html:

 XML/HTML Code复制内容到剪贴板

  1. <div class="^_^"></div>

 

 

  css中的定义:

  CSS Code复制内容到剪贴板

  .5E _5E {width:50px;height:50px;background:tomato;}

  这里的^属于特殊字符,但通过代码写法后,就可以正确解析了。

  关于css字符转义的更多介绍,推荐你阅读CSS character escape sequences,这位作者还给了一个很有用的转义工具。

  让命名更有趣

  还需要提示一下的是,ISO 10646包含的字符,有很多即使看起来很奇特,但由于不是特殊字符,是可以直接输入的。尽管可能因为编辑器字体原因无法显示,但仍然有效。比如,html:

  XML/HTML Code复制内容到剪贴板

  

music on~

 

  对应css:

  CSS Code复制内容到剪贴板

  .?{width:50px;height:50px;background:mistyrose;color:#333;}

  对应的实际元素是(对的,我要证明这个写法有效!):

  music on~

  如果你想表示关于音乐内容的区域,这样字符图形也许可以说比英文单词更加符合语义。而更重要的是,这种写法更有趣!

  在使用这些字符的时候,请注意,css和html的编码都应使用utf-8。如果html是服务器端语言(比如php)生成的,则编码选项应设置为utf-8。

  关于如何找到各种字符,欢迎到Unicode查询站点Unicode character table。

  看到这里,你是否已经想开始写点不一样的选择符命名呢?我已经试过一些↓

  html:

  XML/HTML Code复制内容到剪贴板

  1. <div class="(?ρ?*)"></div>
  2. <div class="(?ω?)"></div>

 

 

  css:

  CSS Code复制内容到剪贴板

  .(?ω?){width:50px;height:50px;background:skyblue;}

  .(?ρ?*){width:50px;height:50px;background:aquamarine;}

  以后觉得词不达意的时候,就用这种吧,一定可以给某个看你代码的人一个惊喜。

  结语

  实际地了解css语法对于命名标识符的规定后才知道,命名时原来还有如此多的空间可以发挥。一起试试更多的有趣的选择符吧!

时间: 2024-10-28 12:27:16

解析css中的选择符命名的相关文章

CSS中的选择符实际使用指南

  在我最早开始写css的时候,其代码上的高自由度就一直很令我困惑.这就是说,同一个设计,如果让不同的人来实现,最终的代码一定是有差异的.但这存在一个问题,如果不同的人通过不同的方法以及代码风格,都从外观上实现了一样的设计,将很难评价谁做得更好.想来也是,既然都实现了设计,达到了目的,css这种没有程序逻辑的代码中,又能找出什么来说明谁做得更出色呢? 而如今,我认同的观念是,css这种描述性语言,仍然有着代码上的质量评判.评判标准就是可维护性(Maintainability)和性能(Perfor

解析css中30个最常用的选择器

文章简介:30个最常用css选择器解析. 你也许已经掌握了id.class.后台选择器这些基本的css选择器.但这远远不是css的全部.下面向大家系统的解析css中30个最常用的选择器,包括我们最头痛的浏览器兼容性问题.掌握了它们,才能真正领略css的巨大灵活性. 1. * {    margin: 0;    padding: 0;   } 星状选择符会在页面上的每一个元素上起作用.web设计者经常用它将页面中所有元素的margin和padding设置为0. *选择符也可以在子选择器中使用.

浏览器IE6不支持的CSS样式的选择符

1. child selector h1 > strong { color:red;} 无效, 只能使用 h1 strong {color:red; } 不支持子选择符,但支持派生选择符. 2.sibling selector li+li { font-style:bold; } 无效. 3.Pseudo-Class Selector有限支持. a:link :visited { color:#fff;},只认最后一个:visited. 最好按如下顺序写: a:link {color: navy

深入学习网页技术CSS中选择符的应用

css|网页 一.选择符模式 模式/含义/内容描述 * 匹配任意元素.(通用选择器) E 匹配任意元素 E (例如一个类型为 E 的元素).(类型选择器) E F 匹配元素 E 的任意后代元素 F .(后代选择器) E > F 匹配元素 E 的任意子元素 F .(子选择器) E:first-child 当元素 E 是它的父元素中的第一个子元素时,匹配元素 E .(:first-child 伪类) E:link E:visited 如果 E 是一个目标还没有访问过(:link)或者已经访问过(:v

javascript中获取页面所有选择符的css规则实现代码

 代码如下 复制代码 <script type="text/javascript"> /* ################################################### * 说明:用 javascript 获取页面上有选择符的 CSS 规则 * 包括'内部样式块'和'外部样式表文件' * 作者:Yanfu Xie [xieyanfu@yahoo.com.cn] * 网址:http://www.111cn.net * 日期:2007.01.16 *

网页制作知识之详细讲解CSS选择符

css|网页 一.选择符模式 模式/含义/内容描述 * 匹配任意元素.(通用选择器) E 匹配任意元素 E (例如一个类型为 E 的元素).(类型选择器) E F 匹配元素 E 的任意后代元素 F .(后代选择器) E > F 匹配元素 E 的任意子元素 F .(子选择器) E:first-child 当元素 E 是它的父元素中的第一个子元素时,匹配元素 E .(:first-child 伪类) E:link E:visited 如果 E 是一个目标还没有访问过(:link)或者已经访问过(:v

CSS初级教程&amp;nbsp;选择符&amp;nbsp;属性和值

HTML有标签(tag),CSS就有选择符(selector).选择符就是赋予内部或者外部样式表的名字.在 CSS初级指南中,我们致力于HTML选择符,即是HTML的标签,用来改变一个指定标签的样式.每个选择符都有属性(properties)在大括号{}中,里面包括诸如color.font-weighth或者 background-color形式的字样.值(value)在半角英文引号:后面,用半角英文分号;隔离. body { font-size: 0.8em; color: navy; } 如

CSS中最小高度(min-height)的妙用

最小高度可以设定一个BOX的最小高度,当其内容较少时时,也能保持BOX的高度为一定,超出就自动向下延伸,但到目前为止,只有Opera 和 Mozilla 支持,IE7开始也支持了,但IE7处于测试阶段,等正式版发布到普及需一段也许比较长的时间,除非MS把它捆绑在某个操作系统上,如何在现有基础上(IE6 80-90%),合理.妙用最小高度了? 假定有二个BOX,我们需要它的最小高度为150PX. CSS: div.box1,div.box2{ width:300px; min-height:150

CSS标签语法:详解选择符中的关系选择符

文章简介:CSS标签语法:详解选择符中的关系选择符. 相信大家都对CSS选择符都不陌生,选择符包含:元素选择符.关系选择符.属性选择符.伪类选择符.伪对象选择符.在众多的选择符中,可以让我们根据自己的需要更加灵活性的选择合适的选择符来对样式进行编写,达到最大的质量和效率. 今天就为大家介绍下选择符中的关系选择符,"关系"这可是一等一的大事啊,我们得理清楚,这样做事情才能更加的有效率.不然在CSS中有你受的,哈哈.关系选择符有四个类别:包含选择符.子选择符.相邻选择符.兄弟选择符.接下来