- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在以字符串形式从磁盘读取 CSS 文件。
我的目标是提取与特定数据属性配对的 HTML 类,如下所示:
.foo[data-my-attr]
数据属性足够独特,因此我不必费心遍历 CSS AST。我可以简单地使用这样的正则表达式:
(\.\S+)+\[data-my-attr\]
这已经可以工作了,但是 \S+
显然是一种在选择器中匹配 HTML 类的糟糕方法。它将包括各种组合器、伪类、伪选择器等。
我尝试构建正则表达式的白名单版本,e。 G。 (\w|-)+
,但是类名的 HTML5 规范非常宽松。我不可避免地会漏掉某些字符或包含不正确的字符。
什么正则表达式可用于从 CSS 选择器字符串中提取 HTML5 类?
我正在使用 Node,我。 e.正则表达式的 JavaScript 风格。
一些例子:
.foo[data-my-attr]
-- 应该匹配 .foo
.foo>span[data-my-attr]
-- 不应该匹配.I_f%⌘ing_♥_HTML5[data-my-attr]
-- 应该匹配 .I_f%⌘ing_♥_HTML5
存在这个问题是因为我想不出所有可能的有效 HTML5 类。我需要一个基于令人惊讶的模糊 HTML5 类规范的正则表达式:
The attribute, if specified, must have a value that is a set of space-separated tokens representing the various classes that the element belongs to.
The classes that an HTML element has assigned to it consists of all the classes returned when the value of the class attribute is split on spaces. (Duplicates are ignored.)
There are no additional restrictions on the tokens authors can use in the class attribute, but authors are encouraged to use values that describe the nature of the content, rather than values that describe the desired presentation of the content.
很明显,一个类不应该包含空格和像 +>:()[]=~
这样的字符,因为它们是 CSS 选择器语法的一部分......
最佳答案
你不应该使用正则表达式。
一个更可靠的替代方案是 PostCSS(及其解析器)。有了它,您将获得整个样式表的完整 AST(抽象语法树),有了它,您将能够轻松提取您要查找的部分。
const postcss = require('postcss');
const Tokenizer = require('css-selector-tokenizer');
let output = [];
const postcssAttributes = postcss.plugin('postcss-attributes', function() {
return function(css) {
css.walkRules(function(rule) {
rule.selectors.map(selector => {
const tokenized = Tokenizer.parse(selector);
if (
tokenized.nodes.some(({ nodes }) =>
nodes.some(
node =>
node.type === 'attribute' && node.content === 'data-my-attr'
)
)
) {
output.push(selector);
}
});
});
};
});
const css = `
.foo[data-my-attr] {
color: red;
}
.foo[something] {
color: red;
}
`;
postcss([postcssAttributes])
.process(css)
.then(result => console.log(output));
// logs: [ '.foo[data-my-attr]' ]
这将记录所有匹配的选择器。
关于javascript - 从 CSS 选择器字符串中提取 HTML5 类的正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47485557/
我正在用 yacc/bison 编写一个简单的计算器。 表达式的语法看起来有点像这样: expr : NUM | expr '+' expr { $$ = $1 + $3; } | expr '-'
我开始学习 lambda 表达式,并在以下情况下遇到了以下语句: interface MyNumber { double getValue(); } MyNumber number; nu
这两个 Linq 查询有什么区别: var result = ResultLists().Where( c=> c.code == "abc").FirstOrDefault(); // vs. va
如果我们查看 draft C++ standard 5.1.2 Lambda 表达式 段 2 说(强调我的 future ): The evaluation of a lambda-expressio
我使用的是 Mule 4.2.2 运行时、studio 7.5.1 和 Oracle JDK 1.8.0_251。 我在 java 代码中使用 Lambda 表达式,该表达式由 java Invoke
我是 XPath 的新手。我有网页的html源 http://london.craigslist.co.uk/com/1233708939.html 现在我想从上面的页面中提取以下数据 完整日期 电子
已关闭。这个问题是 off-topic 。目前不接受答案。 想要改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 已关闭10 年前。 Improve th
我将如何编写一个 Cron 表达式以在每天上午 8 点和下午 3:30 触发?我了解如何创建每天触发一次的表达式,而不是在多个设定时间触发。提前致谢 最佳答案 你应该只使用两行。 0 8 * * *
这个问题已经有答案了: What do 3 dots next to a parameter type mean in Java? (9 个回答) varargs and the '...' argu
我是 python 新手,在阅读 BeautifulSoup 教程时,我不明白这个表达式“[x for x in titles if x.findChildren()][:-1]”我不明白?你能解释一
(?:) 这是一个有效的 ruby 正则表达式,谁能告诉我它是什么意思? 谢谢 最佳答案 正如其他人所说,它被用作正则表达式的非捕获语法,但是,它也是正则表达式之外的有效 ruby 语法。 在
这个问题在这里已经有了答案: Why does ++[[]][+[]]+[+[]] return the string "10"? (10 个答案) 关闭 8 年前。 谁能帮我处理这个 JavaSc
这个问题在这里已经有了答案: What is the "-->" operator in C++? (29 个答案) Java: Prefix/postfix of increment/decrem
这个问题在这里已经有了答案: List comprehension vs. lambda + filter (16 个答案) 关闭 10 个月前。 我不确定我是否需要 lambda 或其他东西。但是,
C 中的 assert() 函数工作原理对我来说就像一片黑暗的森林。根据这里的答案https://stackoverflow.com/a/1571360 ,您可以使用以下构造将自定义消息输出到您的断言
在this页,John Barnes 写道: If the conditional expression is the argument of a type conversion then effec
我必须创建一个调度程序,它必须每周从第一天上午 9 点到第二天晚上 11 点 59 分运行 2 天(星期四和星期五)。为此,我需要提供一个 cron 表达式。 0-0 0-0 9-23 ? * THU
我正在尝试编写一个 Linq 表达式来检查派生类中的属性,但该列表由来自基类的成员组成。下面的示例代码。以“var list”开头的 Process 方法的第二行无法编译,但我不确定应该使用什么语法来
此 sed 表达式将输入字符串转换为两行输出字符串。两条输出行中的每一行都由输入的子串组成。第一行需要转换成大写: s:random_stuff\(choice1\|choice2\){\([^}]*
我正在使用 Quartz.Net 在我的应用程序中安排我的工作。我只是想知道是否可以为以下场景构建 CRON 表达式: Every second between 2:15AM and 5:20AM 最
我是一名优秀的程序员,十分优秀!