我有这个超文本标记语言,我正在尝试将href从photo.php转换为#photo,等等
<ul id="menu">
<li id="home" class="tab_selected"><a href="home.php">Home</a></li>
<li id="portfolio"><a href="portfolio.php">Portfolio</a></li>
<li id="music"><a href="music.php">Music</a></li>
<li id="video"><a href="video.php">Video</a></li>
<li id="photo"><a href="photo.php">Photo</a></li>
</ul>我一直在尝试这样的东西:
$('#menu li a').attr('href', "#"+$(this).parent().attr('id'));但是href总是没有定义。
我将散列存储在li#id中,但如果我不能这样做,那就更好了。
谢谢。
发布于 2011-08-18 19:11:39
$(this)不会引用您认为它所引用的对象。
使用.attr,您可以使用一个函数作为第二个参数,为每个匹配的元素计算新的属性值,如下所示:
// i == index, val == value of href at index i
$('#menu li a').attr('href', function(i, val) {
return '#' + $(this).parent().attr('id');
});在上面的例子中,this引用了正确的上下文(当前迭代的锚元素)。
发布于 2011-08-18 19:10:51
所有jQuery
$('#menu li a').each(function () {
var a = $(this);
a.attr('href', "#" + a.parent().attr('id');
});第jQuery部分
$('#menu li a').each(function () {
this.href = "#" + $(this).parent()[0].id;
});更少的部件jQuery
$('#menu li a').each(function () {
this.href = "#" + this.parentNode.id;
});选择您的选项:)
发布于 2011-08-18 19:13:21
问题是this没有包含错误的值(它引用了可能存在的任何包装上下文),因为您没有处于正确的上下文中。查看(当前)其他3个答案中的任何一个,以了解如何解决此问题(hint, you want to use each)
https://stackoverflow.com/questions/7106394
复制相似问题