将不同列表中的两个列表类相互交换

时间:2013-12-24 23:17:09

标签: jquery list function swap items

我想交换两个不同列表中的元素。因此,如果我在左侧列表和右侧列表中选择某些内容,则需要进行交换。

目前看起来像这样: HTML:

<ul id="sortable1" class="connectedSortable">
    <li value="1" class="ui-state-default">Sort1 Item 1</li>
    <li value="2" class="ui-state-default">Sort1 Item 2</li>
    <li value="3" class="ui-state-default">Sort1 Item 3</li>
    <li value="4" class="ui-state-default">Sort1 Item 4</li>
    <li value="5" class="ui-state-default">Sort1 Item 5</li>
</ul>

<ul id="sortable2" class="connectedSortable">
    <li value="1" class="ui-state-highlight">Sort2 Item 1</li>
    <li value="2" class="ui-state-highlight">Sort2 Item 2</li>
    <li value="3" class="ui-state-highlight">Sort2 Item 3</li>
    <li value="4" class="ui-state-highlight">Sort2 Item 4</li>
    <li value="5" class="ui-state-highlight">Sort2 Item 5</li>
</ul>

Jquery的:

var testClickSort1 ='';
var testClickSort2 ='';

$(function() {
    $("#sortable1").sortable({
        cursor: 'pointer',
        connectWith: ".connectedSortable"
    }).disableSelection();

$("#sortable2").sortable({
    cursor: 'pointer',
    connectWith: ".connectedSortable"
}).disableSelection();

$("#sortable1 li").on('click',function(){
       // $("#testClickSort1").html($(this).attr('value'));
        testClickSort1 = $(this).attr('value'); 
        test();
});

$("#sortable2 li").on('click',function(){
       // $("#testClickSort2").html($(this).attr('value'));
        testClickSort2 = $(this).attr('value');
        test();
});
});

 function test(){ 
      if ((testClickSort1 != "") && (testClickSort2 != "")) {
         alert ("test: " + testClickSort1 + '' +  testClickSort2);
         //function to swap testclicksort1 with testclicksort2
         testClickSort1 = '';
         testClickSort2 = '';
}   
}

可以在这里查看:

http://jsfiddle.net/qkCcS/26/

现在我需要知道将testclicksort1与testclicksort2交换的功能。

提前致谢。

映入眼帘,

的Wouter

1 个答案:

答案 0 :(得分:1)

可以这样做:

$(".connectedSortable").on('click','li', function () {
        /* make sure only one selected at a  time in a list*/
        $(this).siblings().removeClass('selected')
        $(this).toggleClass('selected');
        switchSelectedItems()
 }); 

function switchSelectedItems() {
    var $selected = $('.selected');
    /* make sure there is a pair*/
    if ($selected.length == 2) {
        $selected.each(function () {
            $(this).after($selected.not(this).clone().removeClass('selected'));
        }).remove()
    }
}

此代码的作用是复制每个选定的项目,在其他列表中匹配后放置,然后删除原件

DEMO