首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >简化jQuery代码简化

简化jQuery代码简化
EN

Stack Overflow用户
提问于 2013-01-30 17:30:36
回答 2查看 153关注 0票数 0
代码语言:javascript
复制
<!-- Brands -->
<div class="brands">
  <ul class="thumbnails">
    <li class="span3"> <a href="#" class="thumbnail"> hello1 </a> </li>
    <li class="span3"> <a href="#" class="thumbnail"> hello2 </a> </li>
    <li class="span3"> <a href="#" class="thumbnail"> hello3 </a> </li>
    <li class="span3"> <a href="#" class="thumbnail"> hello4 </a> </li>
    <li class="span3"> <a href="#" class="thumbnail"> hello5 </a> </li>
    <li class="span3"> <a href="#" class="thumbnail"> hello6 </a> </li>
    <li class="span3"> <a href="#" class="thumbnail"> hello7 </a> </li>
    <li class="span3"> <a href="#" class="thumbnail"> hello8 </a> </li>
  </ul>
</div>

这是我的html代码,这是我的jQuery代码。

代码语言:javascript
复制
$(document).ready(function () {
$('.brands li').click(function () {
    var index = $(this).index();
    alert(index);

    if (index < 4) {
        alert('less than 4');
    }

    if (index > 4 && index < 8) {
        alert('less than 8');
    }

    if (index > 8 && index < 12) {
        alert('less than 12');
    }

  });
});

我稍后尝试在第4个li之后插入一个新li,如果li小于第4个孩子,则在第8个li之后插入一个新li,如果le小于第8个孩子,依此类推。有没有办法简化而不是使用大量的if语句?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-01-30 17:40:34

您可以做的是:

代码语言:javascript
复制
var section=4*~~(index/4);
$('.brands li:nth-child('+section+')').append('<span>new li</span>');

这将对您的索引进行整数除法,留下适合您的值的4的倍数。https://stackoverflow.com/a/4228528/1260792

票数 1
EN

Stack Overflow用户

发布于 2013-01-30 17:36:07

您可以使用它来计算它是哪个组,而不是if语句:

代码语言:javascript
复制
var group = parseInt((index - 1) / 4) + 1;
alert((group * 4) + " or less");

或者这样:

代码语言:javascript
复制
var group = parseInt(index / 4) + 1;
alert("less than " + (group * 4));

这取决于你想要什么,因为你的问题与你的示例代码不匹配。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14600564

复制
相关文章

相似问题

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