- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我有下面的脚本
var els = document.getElementsByTagName("a");
for(var i = 0, l = els.length; i < l; i++) {
var el = els[i];
el.innerHTML = el.innerHTML.replace(/link1/gi, 'dead link');
}
然而,由于有很多链接,因此搜索整个页面大约需要 20 秒。
但是,我只需要定位具有特定 href
的 a
,例如。 http://domain.example/
所以理想情况下,我希望能够以与 jQuery 类似的方式执行此操作,但不使用框架。所以像
var els = document.getElementsByTagName("a[href='http://domain.example']");
我该怎么做才能让它只搜索具有匹配 href
的对象?
最佳答案
这个问题发布到现在已经 4 年多了,事情取得了很大进展。
您不能使用:
var els = document.getElementsByTagName("a[href='http://domain.example']");
但是您可以使用的是:
var els = document.querySelectorAll("a[href='http://domain.example']");
(注意:浏览器支持见下文)
这将使您问题中的代码完全按照您的预期工作:
for (var i = 0, l = els.length; i < l; i++) {
var el = els[i];
el.innerHTML = el.innerHTML.replace(/link1/gi, 'dead link');
}
如果您想要所有以 开头 的链接,您甚至可以使用像
:a[href^='http://domain.example']
这样的选择器http://domain.example'
var els = document.querySelectorAll("a[href^='http://domain.example']");
for (var i = 0, l = els.length; i < l; i++) {
var el = els[i];
el.innerHTML = el.innerHTML.replace(/link/gi, 'dead link');
}
参见:DEMO
根据 Can I use 截至 2016 年 6 月的浏览器支持看起来不错:
(有关最新信息,请参阅:http://caniuse.com/queryselector)
IE6 和 IE7 不支持,但是 IE6 is already deadIE7 很快就会有它的 0.68% market share 。
IE8 已经超过 7 年了,它部分 支持 querySelectorAll - 我所说的“部分”是指你可以像 [attr]
这样使用 CSS 2.1 selectors >、[attr="val"]
、[attr~="val"]
、[attr|="bar"]
和一个CSS 3 selectors 的一小部分幸运的是包括:[attr^=val]
、[attr$=val]
和 [attr*=val]
所以看来 IE8我上面的例子没问题。
IE9、IE10 和 IE11 都支持 querySelectorAll 没有问题,Chrome、Firefox、Safari、Opera 和所有其他主要浏览器 - 桌面和移动设备.
换句话说,我们似乎可以安全地开始在生产中使用querySelectorAll
。
有关详细信息,请参阅:
另请参阅 this answer,了解 querySelectorAll
、querySelector
、queryAll
和 query
之间的区别以及它们何时被 < strong>从 DOM 规范中删除。
关于JavaScript 通过 href 获取元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10572735/
我正在尝试通过 node.js 中的 puppeteer 抓取数据 目前,我正在寻找一个脚本,用于抓取 well.ca 某个部分中的所有数据 现在,这是我试图通过 node.js 实现的方法/逻辑 1
href=""、href="#" 和 href="javascript:void(0)" 之间有什么区别? 它们有哪些不同的用途,什么时候一个比另一个更好? 最佳答案 href=""将重新加载当前页面
这是html代码: Delivery Schedule Route Abstract Report 我有 href 值。使用 href 值,我应该找到 anchor 标记并使用 jQuery
我不确定是不是因为我使用的是 Wordpress 但 this.href 没有返回包含它们的项目的 href(例如在“联系人”上它返回 http://www.domain.net/undefined反
这个问题在这里已经有了答案: Is there a "previous sibling" selector? (33 个答案) 关闭 8 年前。
这个问题在这里已经有了答案: Are you allowed to nest a link inside of a link? (9 个回答) 关闭 6 年前。 我有一个可点击的面板,其中有一个工具
我的 css 如下所示 ul.sometclass li a { display:inline-block; } 我的 html 看起来像 outer test
我没看明白这段代码是什么意思? a[href*=#]:not([href=#]) 谢谢! 最佳答案 简单地: a[href*=#] 获取 href 中包含 # 的所有 anchor (a)。 但是有:
document.getElementById("IDOFELEMENT"); 将其转换为链接的正确方法是什么? 我可以写吗 document.getElementById("IDOFELEME
所以我在我的 Next JS 应用程序中遇到了这个奇怪的问题,我导入了谷歌字体,如下所示 在我的浏览器中显示的不是 href,而是 data-href="...",所以问题是谷歌无法将此识别为链接
我想获取所选选项的 href 值,以便我现在可以转到使用按钮选择的链接。 这是我的代码
我正在尝试获取我的一个链接的 href 并将其克隆/复制到另一个链接的 href 这是我正在尝试的 var link = $('.topbook'); var link2 =
我基本上是试图从一个链接获取href,然后将其填充到另一个链接中: HTML: Link to thing Link to duplicate 脚本: $('.main-link').attr('hr
我使用的 CSS 工具提示必须包含在“a href”中才能工作。 iPad [add_to_cart_anchor item="ipad"]purchase the iPad[/add_to_c
我有一个以前是纯文本的电子邮件正文,但现在我把它变成了 HTML。电子邮件是使用多种方法生成的,但没有一种方法易于转换。 我有的是: Some content emailaddress@somethi
我正在尝试从网页中抓取数据,然后通过提取下一页的 href 来转到下一页。 但是,在这种情况下,包含下一页的 href 的标签是 href='#next'。使用 Chrome 检查此元素后,当我将鼠标
在我的 html 页面中,我看到一个链接,其“查看源代码”代码如下: 当我将鼠标悬停在链接上并单击它时,我看到了一个有效链接。但我无法找到生成此 URL 的位置和方式。我发现类 a.view 是在其
看完这篇文章net.tutsplus.com/tutorials/javascript-ajax/14-helpful-jquery-tricks-notes-and-best-practices/我
我想用 SvelteKit 构建一个 Web 应用程序,其中一页列出所有项目(带有潜在的搜索查询参数),然后每个单独的项目一页。如果我必须使用后端生成的所有内容以老式方式构建它,我的路径将是 /ite
此 js 搜索包含 page=fleet 的 href其中: var links = document.querySelectorAll('a[href*="page=fleet"]'); var h
我是一名优秀的程序员,十分优秀!