1

我有这样的 HTML 代码:

<li><input type="hidden" value="001" class="block-hidden-input" />
    <a href="#" id="manage-1" class="manage-content-link">
        <img src="images/web-block/web-block1.jpg"/>
        <span class="orange-notice">Click to Edit Content</span>    
    </a>
</li>

<li><input type="hidden" value="002" class="block-hidden-input" />
    <a href="#" id="manage-2" class="manage-content-link">
        <img src="images/web-block/web-block2.jpg"/>
        <span class="orange-notice">Click to Edit Content</span> 
    </a>
</li>

每个 li 标签都有唯一的 id,格式如下:id="manage-X"。每个用户可以有多个 li 标签,所以它是动态的。

另一方面,我需要这个 jQuery 来处理 li 标签:

$('#manage-1').click(function(e) { 
    $(this).next(".manage-content-wrap").find(".manage-content").load("file-001.php");
    e.preventDefault();
});
$('#manage-2').click(function(e) { 
    $(this).next(".manage-content-wrap").find(".manage-content").load("file-002.php");
    e.preventDefault();
});

这个 jQuery 看起来很糟糕。因为它是静态的,如果我有 5 个 li 标签,意味着我必须复制粘贴 5 次。我不知道如何在 jQuery 上使其动态化。

另外,“file-001.php”和“file-002.php”是基于 li 的值。所以,它必须是这种格式的文件-XXX.php(将XXX替换为li的值)。我想这一定与RegEx有关。但我不知道该怎么做......

知道如何基于 li 标签使 jQuery 动态化吗?谢谢!

4

3 回答 3

3

尝试将您的选择器更改为基于类。然后,您只需要一种方法来确定要加载哪个文件。以下示例假定隐藏输入的值包含要加载的文件编号:

$('a.manage-content-link').click(function (e) {
    var self = $(this),
        file = self.siblings('input[type="hidden"].block-hidden-input').val();
    self.next(".manage-content-wrap").find(".manage-content").load("file-" + file + ".php");
    e.preventDefault();
});
于 2012-10-19T01:42:21.557 回答
2

尝试以下操作,请注意,这"file-00"+this.id.split('-')[1]+".php"只会迎合但您应该能够解决大于 9 的file-001.phpfile-009.php

$('[id^=manage-').click(function(e) { 
    $(this).next(".manage-content-wrap").find(".manage-content").load("file-00"+this.id.split('-')[1]+".php");
    e.preventDefault();
});
于 2012-10-19T01:43:18.800 回答
1

尝试一个 for 循环。

for (var i = 0; i < numberOfFiles; i++)
{ 
    $('#manage-'+i).click(function(e) { 
    $(this).next(".manage-content-wrap").find(".manage-content").load("file-00"+i+".php");
    e.preventDefault();
    });
}
于 2012-10-19T01:42:07.703 回答