jq---data()方法的妙用

有这样一种场景:将左侧表格中的内容在点击添加的时候,右侧列表会增加相应的一列数据,然而反过来还需要点击右侧列的删除时相应的对左侧表格中的对应行操作,此时可以用jq的data()方法,在第一步点击左侧表格添加的时候向该行附加数据,然后左侧点击删除的时候根据附加的数据选择对应行!其实质是把附加数据作为标记,代码如下:

// 左侧点击添加到右侧列表
    $('.nowkucun_table1').on('click','.add_putin',function(){

//获取该行
        var $tr = $(this).parents('tr');

//向该行附加wid和number数据
        var wid = $tr.data('wid');
        var number = $tr.data('number');
        $(this).text('已加入出库单');
        $(this).attr('disabled','disabled');
        $(this).css('color','rgb(180,180,180)');
        var putout_text=$(this).parent().siblings('.text_td').text()

//添加到右侧列表data-wid = "'+wid+'" data-number = "'+number+'"是附加数据,供后面的移除函数调用
        var putout_li='<li class="addwuzili" data-wid = "'+wid+'" data-number = "'+number+'">'+'<span>'+putout_text+'</span>'+'<div><div><div class="reduce">-</div><div><input type="text" name="chukunumber[]" class="form-control materia_num" value="1" readonly><input type="hidden" name="chukuids[]" value="'+wid+'" readonly></div><div class="add">+</div></div><div><img src="/assets/admin/images/iconDelete.png" onclick="removeli(this);"></div></div></li>'
        $('.nowkucun_ul').append(putout_li);
        $('.no_putout').hide();
        hejinum();
    })
    
    //移除改列表,并对应改变左侧表格的数据
    function removeli(that){

//获取刚才添加的数据
        var wid = $(that).parents('li').data("wid");

//将获取的附加数据用到选择器上
        $('#searchlist #list'+wid).find('td').eq(8).find('.add_putin').text('加入出库单').removeAttr('disabled').css('color','#2894FF');
        $(that).parents('li').remove();
        if($(".nowkucun_ul li").length < 2){
            $('.nowkucun_ul .no_putout').show();
        }
        hejinum();
    }

猜你喜欢

转载自blog.csdn.net/wangle_style/article/details/79804530