问题描述
我看过帖子,但似乎没有答案可以帮助我的情况。
我目前使用插件easytab)创建几个不同的选项卡,每个选项卡包含一个标签,如 选择ID为 tab1 $ c $的单个 < a> 元素C>。要更改单个元素的 href 属性,每个不需要。
var href = $('a#tab1')。attr('href')+'?startDate = 20160121& endDate = 20160212';
$('a#tab1')。attr('href',href);
如果有多个ID相同的元素, ID应该是唯一的。
要选择所有以 tab 开头的元素,可以使用。我建议在它们上使用一个独特的类。
要更改所有匹配的 href 属性值元素在 更新: 再说一次, ID应该是唯一的。,您可以使用class而不是ID为类似目的的元素。 更改标记以使用class 然后使用选择器 不良做法: 如果您无法更改标记(由某个插件自动生成标记),那么您可以使用属性值选择器来选择所有具有相同ID的元素。 I have seen the post How to update (append to) an href in jquery? , but it doesn't seem like the answer can help at my case. I am currently using a plugin(easytab) to create a few different tab and every tab contains a tag like <a id="tabopen" href="www.text.com/custom/questions/ask/"> <a id="tabopen" href="www.text.com/default/questions/ask/"> and for some reason I have a button which append some extra path to all the href in order to redirect user to the right place. I have tried to use but instead append the 'startDate=20160121?endDate=20160212' it replace everything to www.text.com/custom/questions/ask/startDate=20160121?endDate=20160212 , which is not right, how should i fix it? Update 1:I am sorry that i have provide wrong description at, the ids are actually the same in the plugin. <a id="tabopen" href="www.text.com/custom/questions/ask/"> <a id="tabopen" href="www.text.com/default/questions/ask/"> $("a#tab1") selects a single <a> element having ID as tab1. To change the href attribute of a single element there is no need of each. If having multiple elements with same ID, ID should be unique. To select all the elements whose ID starts with tab, you can use attribute start with selector. I'll suggest to use a unique class on them. To change the href attribute value of all the matched elements .attr(attributeName, function) with callback function can be used. As said by @charlietfl in the comment, the querystring format should be as follow Update: Saying again, ID should be unique., you can use class instead of ID for similar purpose elements. Change the markup to use class And then use the selector BAD PRACTICE: If you can't change the markup(auto-generated markup by some plugin), you can use attribute value selector to select all elements having same ID 这篇关于在所有的href网址中追加新路径的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持! '? startDate = 20160121& endDate = 20160212'
^ ^
< a class =tabopenhref =www.text.com/custom/questions/ask />
< a class =tabopenhref =www.text.com/default/questions/ask />
<$ p $ $('。tabopen')。something ...
$('a [id =tabopen]')。 ...
$("a#tab1").each(function() {
var _href = $(this).attr("href");
$(this).attr("href", _href + 'startDate=20160121?endDate=20160212');
});
var href = $('a#tab1').attr('href') + '?startDate=20160121&endDate=20160212';
$('a#tab1').attr('href', href);
$('a[id^="tab"]').attr('href', function(i, oldHref) {
return oldHref + '?startDate=20160121&endDate=20160212';
});
'?startDate=20160121&endDate=20160212'
^ ^
<a class="tabopen" href="www.text.com/custom/questions/ask/">
<a class="tabopen" href="www.text.com/default/questions/ask/">
$('.tabopen').something...
$('a[id="tabopen"]').something...