在jQuery中交换两个元素

8

我正在尝试使用向上和向下箭头交换两个元素。

如果有JSFiddle的解决方案就太好了!

我的HTML代码:

<div class="item">
    <div class="content">Some text</div>
    <div class="move">
        <div class="move-down">down</div>
    </div>
</div>
<div class="item">
    <div class="content">Some other text</div>
    <div class="move">
        <div class="move-up">up</div>
        <div class="move-down">down</div>
    </div>
</div>
<div class="item">
    <div class="content">Some text</div>
    <div class="move">
        <div class="move-up">up</div>
        <div class="move-down">down</div>
    </div>
</div>
<div class="item">
    <div class="content">Some other text</div>
    <div class="move">
        <div class="move-up">up</div>
    </div>
</div>

我上一次尝试是:


// el is the clicked one.
jQuery('.move').children().click(function(el) {
    if (jQuery(el).hasClass('move-down') === true) {
        el = jQuery(el).parent().parent();
        el.prependTo(el.after(el));
    } else {
        el = jQuery(el).parent().parent();
        el.appendTo(el.before(el));
    }
});

我尝试了很多不同的方法来更改项目。我试过使用replaceWith()before()after(),但都没有成功。

注意: 我已经编写了一个显示正确上/下DIV的函数。所以第一个和最后一个只能朝一个方向移动。这个问题已经解决了。我也不能使用任何现有的jQuery插件。


你能创建一个 Fiddle 吗? - karthikr
你的 'el' 变量在这里被用于两种不同的方式。 - Derek
1
el 不是被点击的元素,而是事件。this 是被点击的元素。 - Barmar
4个回答

9
你可以这样做 - 你需要检查e.target而不是class = move的div。
jQuery('.move').children().click(function (e) { // <-- argument passed in is the event not an element
    var $div = $(this).closest('.item'); // get closest item div
    if (jQuery(e.target).is('.move-down')) { // check if clicked is movedown
        $div.next('.item').after($div); // if it is move after next
    } else {
        $div.prev('.item').before($div);// else move it before previous
    }
});

演示


3
我可能会做这样的事情:
$(document).ready(function () {
    $('.move-down').click(function (e) {
        var self = $(this),
            item = self.parents('div.item'),
            swapWith = item.next();
        item.before(swapWith.detach());
    });
    $('.move-up').click(function (e) {
        var self = $(this),
            item = self.parents('div.item'),
            swapWith = item.prev();
        item.after(swapWith.detach());
    });
});

这是一个可运行的示例:http://jsfiddle.net/a6Se4/

2

尝试:

jQuery('.move > div').on('click', function(event) {
    var item = jQuery(this).closest('div.item');
    if(jQuery(this).hasClass('move-down')) {
        item.prev('div.item').before(item);
    } else {
        item.next('div.item').after(item);
    }
});

1

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接