3

我正在编写一个获取表格并允许更改列顺序的 jquery 插件。
将位于 oldIndex 位置的列放在 newIndex 位置的代码是:

table.find('> thead > tr, > tbody > tr').each(function() {
    var row = $(this);
    var children = row.children();
    var source = $(children[oldIndex ]);
    var destination = $(children[newIndex ]);

    if (oldIndex != newIndex ) {
        destination
            .replaceWith(source)
            .appendTo(row);
    }
});

问题是每个 td 都有超出此代码的事件。使用时replaceWith,它会删除这些事件。

有什么想法可以替换 DOM 元素的位置并保留其事件吗?

4

2 回答 2

2

确保绑定的函数附加到要移动的元素上。

我建议不要使用replaceWith,而是使用逻辑来交换列。.eq用于选择特定列的索引,.after().before()用于交换列:

演示:http: //jsfiddle.net/SfwXg/

// Indexes are zero-based
var oldIndex = 1;  // = Second column
var newIndex = 2;  // = Third column
var table = $('table');

if (oldIndex != newIndex) {
    if (oldIndex > newIndex) {
        // Let newIndex always be higher than oldIndex
        var tmp = oldIndex;
        oldIndex = newIndex;
        newIndex = oldIndex;
    }
    table.find('> thead > tr, > tbody > tr').each(function() {
//or:table.children('thead,tbody').children().each(function() {
        var row = $(this);
        var children = row.children();
        
        var right = children.eq(newIndex);
        var left = children.eq(oldIndex);
        
        children.eq(newIndex).after(left);
        if (newIndex != oldIndex+1) {
           // If they're next to each other, don't swap the columns
           children.eq(oldIndex+1).before(right);
        }
    });
}
于 2012-01-26T16:50:27.600 回答
1

怎么样:

if (oldIndex != newIndex ) {
    var tmp = $('<td>').insertBefore(destination); // create tmp td before destination
    source.after(destination); // move destination after source
    tmp.after(source).remove(); // move source after tmp, remove tmp
}

编辑:上面的代码交换了 2td秒,这与所要求的不同(移动一个td)。

不管事件有什么问题,如果您想在source之前移动destination,只需执行source.insertBefore(destination)destination.before(source)。在您的代码中,您将destination移至tr.

于 2012-01-26T16:45:39.437 回答