我使用下面的代码通过使用它们的id将页面中的href链接更改为新链接。
这是我用来查找href并向其添加id的方法;
$( document ).ready(function() {
$('a[href$="/truck-bed-covers/camper-tops"]').attr('id', 'camper1');
});
这就是我用来改变链接的地方。
$(document).ready(function () {
$("#camper1").attr("href", "../camper-tops");
});
它工作得很好。除了它不会在页面的其余部分继续。它只更改一个链接,然后就完成了。我如何继续,直到没有更多的链接可更改?
发布于 2021-01-27 03:55:28
ID必须是唯一的,否则JavaScript只能使用第一个ID。
$(document).ready(function() {
$('a[href$="/truck-bed-covers/camper-tops"]').each(function(){
$(this).attr("href", "../camper-tops");
});
});
但我不认为这是正确的方式。您应该找到创建不正确链接的地方,并在那里修复它(在PHP/DB中或链接来自的地方)。
发布于 2021-01-27 03:55:23
在猜测中,您添加了ID以便可以引用第二行中的元素,但您不需要这样做。一旦你有了一个元素,你就可以处理它了。
您可以选择所有具有类似$('a[href]')
的链接(所有具有href属性的链接),然后使用jQuery的each
函数遍历所有这些链接。就像这样
$(function(){ // shorthand for $(document).ready()
$('a[href]').each(function(index, element){
// work on each element here
var $el = $(element);
$el.attr('href', $el.attr('href').replace(/*whatever you want to do here */);
});
});
https://stackoverflow.com/questions/65908302
复制相似问题