首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JS Regex:只选择带有attr的链接(a)

JS Regex:只选择带有attr的链接(a)
EN

Stack Overflow用户
提问于 2019-11-21 08:10:17
回答 2查看 55关注 0票数 0

我必须选择具有特定数据的链接标签(a)。现在我是这样做的:/<a.*?data-extra-url=".*?<\/a>/g。但是..。由于某些原因,当输入字符串没有任何br ->行时,它会导致一个完全错误的选择,例如:

代码语言:javascript
复制
<div> <br> <a data-some-id="3-6-9;id-1-2-3" data-more-id="1-3-5" data-extra-url="https://somehost.api/sub-id-1-2-3?someparam=3-6-9;id-1-2-3" href="https://somehost.api/sub-id-1-2-3?someparam=3-6-9;id-1-2-3" class="some-class">someDuplicateHere1</a></div> wysiwyg<br> <div><a class="popup-wrap-id-1-2-3" href="https://somehost.api/app/id-1-2-3?someparam=sub-id-1-2-3;sub-sub-id-1-2-3">firstImage</a></div> <br> <div>somecontent</div> <div> <span> <div><a data-some-id="456;789" href="https://somehost.api/app/id-4-5-6?someparam=sub-id-4-5-6;sub-sub-1-2-3">second</a></div> <br> </span> also some more content </div> <div> <span> <div><a data-some-id="3-6-9;id-1-2-3" data-more-id="1-3-5" data-extra-url="https://somehost.api/app/sub-id-1-2-3?someparam=3-6-9;id-1-2-3" href="https://somehost.api/app/sub-id-1-2-3?someparam=3-6-9;id-1-2-3" class="some-class">someDuplicateHere</a></div> rtf<br> </span> <br> </div> </div>

还有一个活生生的例子:https://regex101.com/r/JkI3Fu/1

由于某些原因,在我的选择中有所有的链接,我做错了什么?

因此,我想得到:

代码语言:javascript
复制
array = ['<a data-some-id="3-6-9;id-1-2-3" data-more-id="1-3-5" data-extra-url="https://somehost.api/sub-id-1-2-3?someparam=3-6-9;id-1-2-3" href="https://somehost.api/sub-id-1-2-3?someparam=3-6-9;id-1-2-3" class="some-class">someDuplicateHere1</a>', '<a data-some-id="3-6-9;id-1-2-3" data-more-id="1-3-5" data-extra-url="https://somehost.api/app/sub-id-1-2-3?someparam=3-6-9;id-1-2-3" href="https://somehost.api/app/sub-id-1-2-3?someparam=3-6-9;id-1-2-3" class="some-class">someDuplicateHere</a>']
like here: https://regex101.com/r/NiFFXd/1
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-11-21 08:23:27

重要的是,你的裁判看什么,你不想在你的比赛。像这样使用^

代码语言:javascript
复制
<a[^>]*data-extra-url="[^>]*>[^>]*.

它应该能解决你的问题

票数 1
EN

Stack Overflow用户

发布于 2019-11-21 09:37:09

您可以使用

代码语言:javascript
复制
document.querySelectorAll('a[data-extra-url]');

[attribute]选择器用于选择具有指定属性的元素。 来自CSS属性选择器

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58970114

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档