javascript - 通过索引分配属性的最佳方法是什么

标签 javascript jquery attributes attr

我有一个包装器,其中包含所有需要特定位置的子级。

假设我有一个像这样的标记:

<div class="wrapper">
    <div class="slider" data-position=""></div>
    <div class="slider" data-position=""></div>
    <div class="slider" data-position=""></div>
</div>

最后一个子 slider 的位置应为“前”,倒数第二个子 slider 的位置应为“后”,所有其他 slider 的位置应为“边缘”。

演示:http://jsfiddle.net/L5Lpp/1/

我真的不喜欢大量的 if 和 else 语句......

有没有更好更优雅的方法来实现这一点?

最佳答案

您可以获得该项目相对于最后一个项目的索引,并从中计算位置:

var index = currentItem.index() - sliders.length;
currentItem.attr('data-position',
    index == -1 ? 'infront' :
    index == -2 ? 'behind' :
    'limbo'
);

演示:http://jsfiddle.net/L5Lpp/2/

关于javascript - 通过索引分配属性的最佳方法是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24420057/

相关文章:

jquery tooltipster插件,隐藏所有提示?

jquery - 如何将图像叠加在另一个图像之上

javascript - 是否可以使用 C# 添加 Object 的属性

Python 'AttributeError: '函数'对象没有属性 'min''

javascript - jQuery:使用 .find() 命令时出现问题

javascript - Async.js 队列工作程序未完成

javascript - 模拟点击打开 Bootstrap 折叠元素

javascript - 如何使用 JQuery 在到达 div 点时删除文本

javascript - 我的 Javascript for 循环有什么问题

NHibernate Fluent 与属性