• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > 解析css中的选择符命名

解析css中的选择符命名

作者:梁砫 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含css,选择符等相关知识,梁砫 希望在学习及工作中可以帮助到您

原来命名可以这样的

前一段时间,在某一站点看到了这样的内容:
2015728175748338.png (500×156)

"这也可以?"是我对此的第一印象。不过,稍作调查知道了,这样写确实是有效的。此外,这个?_?的符号表情,看起来是不是相当有存在感?再看看搭配的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或者\000023表示。请注意,如果代码不满6位(前面几位是0),一定要在末尾留一个空格,这才能组成一个正确的ISO 10646代码(这个空格是分隔标识用,算作代码的一部分,不会引发选择符中的特殊含义)。如果不想有这个空格,请使用完整的6位十六进制代码。

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

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

css中的定义:

  1. .\5E _\5E {width:50px;height:50px;background:tomato;}  

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

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

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

  1. <div class="?">music on~</div>  

对应css:

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

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

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

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

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

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

html:

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

css:

  1. .\(?ω?\){width:50px;

您可能想查找下面的文章:

  • css小技巧
  • 各大网站CSS初始化代码
  • css权重问题
  • CSS实现鼠标上移图标旋转效果
  • 使用CSS3制作一个简单的进度条(demo)
  • 用纯CSS实现饼状Loading等待图效果
  • 利用CSS3伪元素实现逐渐发光的方格边框
  • CSS3实现内凹圆角的实例代码
  • 利用HTML5+CSS3实现3D转换效果实例详解
  • css3+伪元素实现鼠标移入时下划线向两边展开的效果

相关文章

  • 2017-08-06纯CSS3实现鼠标悬停提示气泡效果
  • 2017-08-06使用css实现圆角图形绘制
  • 2017-08-06验证并修复css错误内容的相关连接
  • 2017-08-06CSS复合选择器使用介绍
  • 2017-08-06css权威指南--笔记(必看)
  • 2017-08-06浅谈css3中的前缀
  • 2017-08-06详细了解CSS中的class与id区别及用法
  • 2017-08-06css 背景样式属性说明
  • 2017-08-06左侧固定宽度,右侧自适应宽度的CSS布局
  • 2017-08-06倾听色彩的声音 网页与产品的配色研究

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 自定义input[type=”file”]的样式
    • 利用边框border属性做小符号
    • 相邻div实现一个跟着另一个自适应高度示例代码
    • url 关于自动换行问题
    • !important用法使用介绍
    • css 高度自适应的问题示例探讨
    • css按坐标取背景图示例代码
    • CSS圆角边框制作指南与实例
    • css3的@media属性实现页面响应式布局示例代码
    • Ztree在低版本浏览器下显示错行问题的解决方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有