首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基于超文本标记语言<li>标签的动态jQuery

基于超文本标记语言<li>标签的动态jQuery
EN

Stack Overflow用户
提问于 2012-10-19 09:36:41
回答 3查看 231关注 0票数 1

我有这样的HTML代码:

代码语言:javascript
复制
<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标记:

代码语言:javascript
复制
$('#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的值。因此,它的格式必须是file-XXX.php (将XXX替换为li的值)。我猜这一定和RegEx有关。但我不知道该怎么做。

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

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-10-19 09:42:22

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

代码语言:javascript
复制
$('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();
});
票数 3
EN

Stack Overflow用户

发布于 2012-10-19 09:43:19

尝试以下方法,请注意,"file-00"+this.id.split('-')[1]+".php"只能满足file-001.phpfile-009.php的要求,但您应该能够计算出大于9的值

代码语言:javascript
复制
$('[id^=manage-').click(function(e) { 
    $(this).next(".manage-content-wrap").find(".manage-content").load("file-00"+this.id.split('-')[1]+".php");
    e.preventDefault();
});
票数 2
EN

Stack Overflow用户

发布于 2012-10-19 09:42:08

尝试使用for循环。

代码语言:javascript
复制
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();
    });
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12966183

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档