jQuery的:
$(document).ready(function() {
$("a.change_status").click(function(){
var status_id = $("a").val();
alert(status_id);
return false;
});
});
HTML:
<a href="?status=5" class="change_status">Aminul</a><br/>
<a href="?status=25" class="change_status">Arif</a><br/>
<a href="?status=15" class="change_status">Sharif</a><br/>
我需要status_id
,由于某种原因我的锚标签是动态的。我不能使用id或make class name dynamic。我想,我需要使用$this
来获取我的价值。
答案 0 :(得分:13)
这个很简单:
$(document).ready(function() {
$("a.change_status").click(function(){
var status_id = $(this).attr('href').split('=');
alert(status_id[1]);
return false;
});
});
答案 1 :(得分:5)
var status_id= $(this).attr("href").match(/status=([0-9]+)/)[1];
答案 2 :(得分:3)
这里有两个不同的问题......首先,您需要使用this
找到实际点击的链接,然后找到该href属性的值。
$(document).ready(function() {
$("a.change_status").click(function() {
var status_id = parseURL($(this).attr("href"));
alert(status_id);
return false;
});
});
另外,由于javascript无法提取URL参数,因此必须编写一个函数(在示例中为parseURL
),在其中查找变量“status”的值:
function parseURL(theLink) {
return decodeURI((RegExp('status=' + '(.+?)(&|$)').exec(theLink) || [, null])[1]);
}
请参阅以下jsfiddle:
答案 3 :(得分:2)
$('a').attr('href');
应该做的伎俩
答案 4 :(得分:1)
$(document).ready(function() {
$("a.change_status").click(function(){
var status_id = $(this).attr("href");
alert(status_id); return false;
});
});
答案 5 :(得分:1)
您可以这样做:
$(document).ready(function() {
$("a.change_status").click(function() {
var status_id = $(this).attr("href");
alert(status_id);
return false;
});
});
答案 6 :(得分:0)
$("a.change_status").click(function(){
var status_id = $(this).attr('href');
alert(status_id);
});
答案 7 :(得分:0)
var listItems = $(".nav-dropdown--products .li");
listItems.each(function(idx, li) {
var product = $(li);
alert($('a', this).attr('href'));
});