admin管理员组文章数量:1136398
On a page I'm doing I will be ending up with custom link
elements like this:
<link rel="multiply" type="service/math" src="path/to/service">
<link rel="substract" type="service/math" src="path/to/service">
...
I'm trying to use querySelectorAll
to retrieve all link elements with a type service/...
specified and am getting nowhere.
Currently I'm selecting this:
root.querySelectorAll('link');
which gives me all <link>
elements when I only want the ones with type service/.*
Questions:
Can I add a regex to a QSA selector? If so, how to do it?
On a page I'm doing I will be ending up with custom link
elements like this:
<link rel="multiply" type="service/math" src="path/to/service">
<link rel="substract" type="service/math" src="path/to/service">
...
I'm trying to use querySelectorAll
to retrieve all link elements with a type service/...
specified and am getting nowhere.
Currently I'm selecting this:
root.querySelectorAll('link');
which gives me all <link>
elements when I only want the ones with type service/.*
Questions:
Can I add a regex to a QSA selector? If so, how to do it?
- 3 take a look at this answer stackoverflow.com/a/38711853/7250868 – Ramil Shavaleev Commented Sep 21, 2020 at 9:39
4 Answers
Reset to default 144You can't really use a regular expression in a selector but CSS selectors are powerful enough for your need with a "starts with" syntax inspired by regexes.
You can use a substring matching attribute selectors : link[type^=service]
Reads "Nodes of type link
with an attribute type
starting with "service"
From the formal specification:
[att^=val]
Represents an element with the att attribute whose value begins with the prefix "val". If "val" is the empty string then the selector does not represent anything.
Working JSFiddle
I know this is 7 years old, but this is how you do it (for attribute values):
function DOMRegex(regex) {
let output = [];
for (let i of document.querySelectorAll('*')) {
if (regex.test(i.type)) { // or whatever attribute you want to search
output.push(i);
}
}
return output;
}
console.log(DOMRegex(/^service\//)); // your regex here
<link rel="multiply" type="service/math" src="path/to/service">
<link rel="substract" type="service/math" src="path/to/service">
<link rel="test" type="notservice/math" src="path/to/notservice">
<div id="some-other-node"></div>
To search all element attributes, you can use this:
function DOMRegex(regex) {
let output = [];
for (let i of document.querySelectorAll('*')) {
for (let j of i.attributes) {
if (regex.test(j.value)) {
output.push({
'element': i,
'attribute name': j.name,
'attribute value': j.value
});
}
}
}
return output;
}
console.log(DOMRegex(/(?<!t)service/)); // your regex here
<link rel="multiply" type="service/math" src="path/to/service">
<link rel="substract" type="service/math" src="path/to/service">
<link rel="test" type="notservice/math" src="path/to/notservice">
<div id="some-other-node"></div>
I put it in a nice object layout for you.
The post is quite old but it may be helpful for someone. If like
clause is needed and we don't want to search by only the start, the following syntax can be used:
document.querySelectorAll('[type*=service]');
For your example below:
<link rel="multiply" type="service/math" src="path/to/service">
<link rel="substract" type="service/math" src="path/to/service">
You cannot use Regular Expression(Regex) but can use CSS Selector for querySelectorAll()
as well as querySelector()
as shown below. *You can see 6.2. Substring matching attribute selectors.
link[type^="service"]
can select all <link>
s whose type
attribute starts from service
:
document.querySelectorAll('link[type^="service"]');
// rel="multiply"'s <link> and rel="substract"'s <link>
[type^="service"]
can also select all <link>
s whose type
attribute starts from service
but I don't recommend it without link
because it is less specific so it may also select other elements:
document.querySelectorAll('[type^="service"]');
// rel="multiply"'s <link> and rel="substract"'s <link>
link[type*="service"]
can also select all <link>
s whose type
attribute contains service
:
document.querySelectorAll('link[type*="service"]');
// rel="multiply"'s <link> and rel="substract"'s <link>
In addition, link[src&="service"]
can also select all <link>
s whose src
attribute ends with service
:
document.querySelectorAll('link[src&="service"]');
// rel="multiply"'s <link> and rel="substract"'s <link>
本文标签: javascriptHow to use a regular expression in querySelectorAllStack Overflow
版权声明:本文标题:javascript - How to use a regular expression in querySelectorAll? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1736964287a1957849.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论