我在企业应用程序中动态生成了几个a标签,如下面的
<a href='JavaScript:SWESubmitForm(document.SWEForm1_0,s_1,"s_1_1_1_0","1-SXPINW")' onclick='Edit_SList__0__Control__Renew_SPO__onclick(null, "s_1_1_1_0")' tabindex=2997 id='s_1_1_1_0'>Renew PO</a>
<a href='JavaScript:SWESubmitForm(document.SWEForm1_0,s_2,"s_1_1_4_0","1-SXP9NW")' onclick='Edit_SList__0__Control__XRXAddFunds__onclick(null, "s_1_1_4_0")' tabindex=2997 id='s_1_1_4_0'>Add Funds</a>
我有下面的jQuery代码来从标签中提取识别记录的唯一值
var href = $('a[href*="SWESubmitForm"]').attr('href');
var rowId = "";
if( href != ""){
hrefAr = href.split('","');
rowId = hrefAr[hrefAr.length - 1];
rowId = rowId.substr(0,(rowId.length - 2));
}
上面的代码为我提供了值1-SXPINW但我需要获得值1-SXP9NW(第二个链接,一页上可能有几个链接)。我需要为文本添加过滤器,基本上只检索具有特定文本(如"添加资金")的链接的值。
我知道可以使用each和addif语句来检查文本,但我想通过过滤器来完成。
请帮忙!!!
编辑:
我想我没有正确解释这个问题。我需要以这样一种方式设置过滤器
if (text within a tag == "Add Funds") then get the value of ID within href attribute
我想根据标签中的text()设置我的过滤器。我希望它能更好地澄清这个问题。
选择所需的元素。。如果有两个,只需使用.eq(),因为它返回所有与选择器匹配的元素。eq将返回一个jquery对象
var href = $('a[href*="SWESubmitForm"]').eq(1).attr('href'); // <-
或将其转换为dom元素
var href = $('a[href*="SWESubmitForm"]')[1].href;
此外,由于您有一个ID
,您可以使用ID
选择器选择您想要的
var href = $('#s_1_1_4_0').attr('href');
或者,如果太多了,你需要找到一个9NW的。。只需在您的支票中使用indexOf
$('a[href*="SWESubmitForm"]').each(function(){
var rowId = "";
if(this.href.indexOf('1-SXP9NW') > -1){ // <-- use indexOf to see if href contains the string
hrefAr = this.href.split('","');
rowId = hrefAr[hrefAr.length - 1];
rowId = rowId.substr(0,(rowId.length - 2));
}
});
具有过滤功能
var href = $('a[href*="SWESubmitForm"]').filter(function(){
return this.href.indexOf('1-SXP9NW') > -1;
}).attr('href');
毕竟。。你为什么不直接用这个选择器呢?
$('a[href*="1-SXP9NW"]')
编辑:
如果Add Funds
是静态的。。然后使用:contains()选择器
var href = $('a:contains("Add Funds")').attr('href');
您可以使用.each()
循环链接并从href属性中提取所需的值。
$('a[href*="SWESubmitForm"]').each(function() {
var rowId = "";
var href = $(this).attr('href');
if (href != "") {
hrefAr = href.split('","');
rowId = hrefAr[hrefAr.length - 1];
rowId = rowId.substr(0, (rowId.length - 2));
console.log(rowId);
}
});