微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在jQuery中移动或交换元素?

目标是在左兄弟或其同胞之前移动一个元素.
<ul>
    <li>One</li>
    <li>Two</li>
    <li>Three</li>
    <li>One</li>
</ul>

只给出元素的索引,我需要将其移动到左或右.说索引是1(LI和“Two”作为innerText),那么我想把它移动到左边,输出应该是:

<ul>
    <li>Two</li>
    <li>One</li>
    <li>Three</li>
    <li>One</li>
</ul>

解决方法

/**
 * @param siblings {jQuery} List of sibling elements to act upon
 * @param subjectIndex {int} Index of the item to be moved
 * @param objectIndex {int} Index of the item to move subject after
 */
var swapElements = function(siblings,subjectIndex,objectIndex) {
    // Get subject jQuery
    var subject = $(siblings.get(subjectIndex));
    // Get object element
    var object = siblings.get(objectIndex);
    // Insert subject after object
    subject.insertAfter(object);
}
$(function() {
    swapElements($('li'),1);
});
​

工作实例:http://jsfiddle.net/faceleg/FJt9X/2/

原文地址:https://www.jb51.cc/jquery/179701.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐