使用带有href的attr函数出错

Error using the attr function with href

本文关键字:attr 函数 出错 href      更新时间:2023-09-26

我得到错误undefined is not a function时运行这段代码:

var links=$("li").find("a");//this works...has a length of 23
//then I run this
for(var i=0;i<links.length;i++){
  links[i].attr("href");//this does not work
}

我能做些什么来获得从链接获得的href属性?

jQuery对象的元素是DOM元素,而不是其他jQuery对象,因此它们没有jQuery方法。您可以使用eq方法访问这些元素的jquery包装版本:

for(var i=0;i<links.length;i++){
    href = links.eq(i).attr("href");
}

或者直接访问属性:

for(var i=0;i<links.length;i++){
    href = links[i].href;
}

在您的示例代码中,您实际上并没有对值进行任何操作,因此您可能也想对其进行排序。

您应该简单地尝试:

$("li a").each(function(){
  console.log($(this).attr('href'));
});

或者修改你的代码来创建一个jquery对象,以便能够使用attr函数:

for(var i=0;i<links.length;i++){
  $(links[i]).attr("href");
}

或者直接使用href:

  links[i].href;