通过单击两个列表项来交换两个不同列表中的内容

时间:2013-12-24 17:51:07

标签: jquery list onclick 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)

不要使用>直接后代选择器。另外,我建议您使用.data()代替.attr()

而不是

 $("ul.icecream>li.active")

使用

 $("ul.icecream li.active")

DEMO

竞争代码

function swap(){
    if($("ul.icecream>li").hasClass("active")){
        var p1_name = $("ul.icecream li.active").data("name");
        var p_name = $(this).data("name");
        $(this).data("name", p1_name).text(p1_name);
        $("ul.icecream li.active").data("name", p_name).text(p_name).removeClass("active");
    }
    else{
        $(this).addClass("active");
    }
}
$("ul.icecream>li").on("click", swap);