在CSS类选择器中允许使用哪些字符/符号?

我知道下面的字符是无效的,但是哪些字符是有效的呢?

~ ! @ $ % ^ & * ( ) + = , . / ' ; : " ? > < [ ] \ { } | ` #

当前回答

你可以直接检查CSS语法。

基本上,名称必须以下划线(_)、连字符(-)或字母(a - z)开头,后面跟着任意数量的连字符、下划线、字母或数字。这里有一个问题:如果第一个字符是连字符,第二个字符必须是字母或下划线,并且名称必须至少有两个字符长。

-?[_a-zA-Z]+[_a-zA-Z0-9-]*

简而言之,前面的规则转换为以下内容,摘自W3C规范:

在CSS中,标识符(包括元素名称、类和id) 选择器)只能包含字符[a-z0-9]和iso10646 字符U+00A0及以上,加上连字符(-)和下划线 (_);它们不能以数字开头,也不能以连字符后跟数字。 标识符还可以包含转义字符和任何ISO 10646 作为数字代码的字符(见下一项)。例如, 标识符“B&W?”可以写成“B&W?”或“B\ 26w \3F”。

以连字符或下划线开头的标识符通常保留给特定于浏览器的扩展,如-moz-opacity。

1由于包含了转义的Unicode字符(没有人真正使用),这一切变得更加复杂。

注意,根据我链接的语法,以两个连字符开头的规则,例如——indent1,是无效的。然而,我很确定我在实践中见过这种情况。

其他回答

完整的正则表达式为:

-?(?:[_a-z]|[\200-\377]|\\[0-9a-f]{1,6}(\r\n|[ \t\r\n\f])?|\\[^\r\n\f0-9a-f])(?:[_a-z0-9-]|[\200-\377]|\\[0-9a-f]{1,6}(\r\n|[ \t\r\n\f])?|\\[^\r\n\f0-9a-f])*

所以你列出的所有字符,除了“-”和“_”,如果直接使用是不允许的。但是您可以使用反斜杠foo\~bar或使用Unicode符号foo\7E bar来编码它们。

阅读W3C规范(这是CSS 2.1;为您的浏览器假设找到合适的版本)

相关的段落:

在CSS中,标识符(包括 中的元素名称、类和id 选择器)只能包含 字符[a-z0-9]和iso10646 字符U+00A1及以上,加上 连字符(-)和下划线(_); 不能以数字或字母开头 连字符后面跟着一个数字。 标识符也可以包含转义 字符及任何iso10646字符 作为数字代码(见下一项)。为 实例中,标识符“B&W?”可以为 写成“B&W?”或“B\ 26w \3F”。

正如@mipadi在Kenan Banks的回答中指出的那样,在同一个网页上也有这样的警告:

在CSS中,标识符可以以“-”开头 (破折号)或“_”(下划线)。关键字 以及以" - "开头的属性名 或者'_'被保留 特定于供应商的扩展。这样的 特定于供应商的扩展应该具有 以下格式之一: '-' +供应商标识符+ '-' +有意义的名称 '_' +供应商标识符+ '-' +有意义的名称 示例(s): 例如,如果添加了XYZ组织 属性来描述的颜色 边境的东部 他们可能称之为“展示” -xyz-border-east-color。 其他已知的例子: -moz-box-sizing -moz-border-radius -wap-accesskey 开头的破折号或下划线是 保证永远不会被用在 属性或关键字由任何当前或 未来的CSS级别。这就是典型的CSS 实现可能无法识别这种情况 属性,并可能忽略它们 按规定办理 解析错误。然而,因为 开头的破折号或下划线是 语法,css2.1实现者 应该总是能使用一个 符合css的解析器,无论是否如此 它们支持任何特定于供应商的产品 扩展。 作者应该避免特定于供应商 扩展

根据Kenan Banks的答案,你可以使用以下两个正则表达式匹配来使字符串有效:

[^a-z0-9A-Z_-]

这是一个反向匹配,选择任何不是字母、数字、破折号或下划线的东西,以便轻松删除。

^-*[0-9]+

它匹配字符串开头的0或1个破折号后面跟着1个或多个数字,也便于删除。

如何在PHP中使用它:

// Make alphanumeric with dashes and underscores (removes all other characters)
$class = preg_replace("/[^a-z0-9A-Z_-]/", "", $class);

// Classes only begin with an underscore or letter
$class = preg_replace("/^-*[0-9]+/", "", $class);

// Make sure the string is two or more characters long
return 2 <= strlen($class) ? $class : '';

你可以直接检查CSS语法。

基本上,名称必须以下划线(_)、连字符(-)或字母(a - z)开头,后面跟着任意数量的连字符、下划线、字母或数字。这里有一个问题:如果第一个字符是连字符,第二个字符必须是字母或下划线,并且名称必须至少有两个字符长。

-?[_a-zA-Z]+[_a-zA-Z0-9-]*

简而言之,前面的规则转换为以下内容,摘自W3C规范:

在CSS中,标识符(包括元素名称、类和id) 选择器)只能包含字符[a-z0-9]和iso10646 字符U+00A0及以上,加上连字符(-)和下划线 (_);它们不能以数字开头,也不能以连字符后跟数字。 标识符还可以包含转义字符和任何ISO 10646 作为数字代码的字符(见下一项)。例如, 标识符“B&W?”可以写成“B&W?”或“B\ 26w \3F”。

以连字符或下划线开头的标识符通常保留给特定于浏览器的扩展,如-moz-opacity。

1由于包含了转义的Unicode字符(没有人真正使用),这一切变得更加复杂。

注意,根据我链接的语法,以两个连字符开头的规则,例如——indent1,是无效的。然而,我很确定我在实践中见过这种情况。

令我惊讶的是,这里的大多数答案都是错误的。事实证明:

CSS类名中除了NUL之外的任何字符都是允许的。(如果CSS包含NUL(转义与否),结果是未定义的。[CSS-characters])

Mathias Bynens的回答链接到如何使用这些名字的解释和演示。在CSS代码中,类名可能需要转义,但这不会改变类名。例如,一个不必要的超转义表示将看起来与该名称的其他表示不同,但它仍然引用相同的类名。

大多数其他(编程)语言没有转义变量名(“标识符”)的概念,因此变量的所有表示必须看起来相同。在CSS中不是这样的。

注意,在HTML中,没有办法在类名属性中包含空格字符(空格、制表符、换行符、换行符和回车符),因为它们已经将类彼此分开了。

因此,如果你需要将一个随机字符串转换为CSS类名:注意NUL和空格,并转义(适用于CSS或HTML)。完成了。