欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

layui監(jiān)聽復(fù)選框checkbox選中以及分頁選中處理方式

 更新時(shí)間:2025年04月01日 15:42:51   作者:hexu_blog  
這篇文章主要介紹了layui監(jiān)聽復(fù)選框checkbox選中以及分頁選中處理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

layui監(jiān)聽復(fù)選框checkbox選中及分頁選中處理

具體實(shí)現(xiàn)代碼如下:

需要關(guān)注三個(gè)位置

  • done表格加載完畢方法
  • cols中復(fù)選框欄定義
  • table.on中對(duì)復(fù)選框選中或取消的狀態(tài)定義

這三個(gè)地方的代碼直接復(fù)制去用就行了

最終選中的數(shù)據(jù)id為:ids

<script>
 
    layui.use(['table', 'form', 'upload','laydate'], function () {
 
        // 設(shè)置全局變量以保存選中行信息(僅需要id的話在你的業(yè)務(wù)位置調(diào)用ids即可,數(shù)據(jù)格式是int數(shù)組)
        let ids = new Array();
 
        // 存儲(chǔ)所有選中的數(shù)據(jù)(需要行內(nèi)全量數(shù)據(jù)在你的業(yè)務(wù)位置調(diào)用lists即可,數(shù)據(jù)格式是對(duì)象集合)
        var lists = new Array();
 
        // 保存當(dāng)前頁全部數(shù)據(jù)id,點(diǎn)擊全選時(shí)使用
        let tableIds = new Array();
 
        //第一個(gè)實(shí)例
        table.render({
            elem: '#currentTableId'
            , method: "post"
            , dataType: "Json"
            , id: 'layuiReload'
            , url: '/page/severalquality/getshipPlan' //數(shù)據(jù)接口
            , toolbar: '#toolbarTem'
            , page: true //開啟分頁
            , done: function (res, curr, count) {
 
                // 設(shè)置當(dāng)前頁全部數(shù)據(jù)id到全局變量
                tableIds = res.data.map(function (value) {
                    return value.id;
                });
                // 設(shè)置當(dāng)前頁選中項(xiàng)
                $.each(res.data, function (idx, val) {
                    if (ids.indexOf(val.id) > -1) {
                        val["LAY_CHECKED"] = 'true';
                        //找到對(duì)應(yīng)數(shù)據(jù)改變勾選樣式,呈現(xiàn)出選中效果
                        let index = val['LAY_TABLE_INDEX'];
                        $('tr[data-index=' + index + '] input[type="checkbox"]').click();
                        form.render('checkbox'); //刷新checkbox選擇框渲染
                    }
                });
                // 獲取表格勾選狀態(tài),全選中時(shí)設(shè)置全選框選中
                let checkStatus = table.checkStatus('test');
                if (checkStatus.isAll) {
                    $('.layui-table-header th[data-field="0"] input[type="checkbox"]').prop('checked', true);
                    form.render('checkbox'); //刷新checkbox選擇框渲染
                }
 
            }
            , cols: [[ //表頭
                { field: 'id', title: '數(shù)據(jù)編號(hào)', sort: true, hide: true }
                , { field: 'id', sort: true, type: 'checkbox' }//在此聲明表格復(fù)選框
                , { field: 'DataNumber', align: 'center', title: '序號(hào)', width: 60, type: 'numbers' }
                , { field: 'shiptitle', align: 'center', title: '船名' }
                , { field: 'carrierstitle', align: 'center', title: '承運(yùn)商' }
                , { field: 'startPortName', align: 'center', title: '始發(fā)港' }
                , { field: 'destPortName', align: 'center', title: '到港' }
                , { field: 'arrivalTime', align: 'center', title: '運(yùn)達(dá)時(shí)間' }
                , { field: 'shipmentTon', align: 'center', title: '裝油量' }
                , { field: 'realTon', align: 'center', title: '卸油量' }
                , {
                    field: 'superConsumption', align: 'center', title: '是否超耗索賠', hide: true, templet: function (res) {
                        if (res.superConsumption == true) {
                            return "是";
                        } else {
                            return "否";
                        }
                    }
                }
                , { field: 'claimSum', align: 'center', title: '索賠量' }
                , { field: 'practicalprice', align: 'center', title: '實(shí)際索賠金額' }
                , { field: 'claimcompensationInfostateName', align: 'center', title: '索賠狀態(tài)' }
                , { field: 'auditremark', align: 'center', title: '審核備注', hide: true }
            ]]
        });
 
 
        //使用on監(jiān)聽checkbox選中狀態(tài)并進(jìn)行處理(tableFilter為table的lay-filter值)
        table.on('checkbox(tableFilter)', function (obj) {
 
            if (obj.checked == true) {
                if (obj.type == 'one') {
                    ids.push(obj.data.id);
                    lists.push(obj.data);
 
                } else {
                    for (let i = 0; i < tableIds.length; i++) {
                        //當(dāng)全選之前選中了部分行進(jìn)行判斷,避免重復(fù)
                        if (ids.indexOf(tableIds[i]) == -1) {
                            ids.push(tableIds[i]);
                            var checkStatus = table.checkStatus('layuiReload'); //layuiReload 為table聲明的id
                            lists.push(checkStatus.data[i]);
                        }
                    }
                }
            } else {
                if (obj.type == 'one') {
                    let i = ids.length;
                    while (i--) {
                        if (ids[i] == obj.data.id) {
                            ids.splice(i, 1);
                            lists.splice(i, 1);
                        }
                    }
                } else {
                    let i = ids.length;
                    while (i--) {
                        if (tableIds.indexOf(ids[i]) != -1) {
                            ids.splice(i, 1);
                            lists.splice(i, 1);
                        }
                    }
                }
            }
        });
 
</script>

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • js彈窗返回值詳解(window.open方式)

    js彈窗返回值詳解(window.open方式)

    本篇文章主要介紹了js彈窗返回值(window.open方式)。需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2014-01-01
  • JS 將字符串中指定字符全局替換的方法

    JS 將字符串中指定字符全局替換的方法

    JavaScript 中的 replace() 方法用于將字符串或其中的子字符串替換為指定字符,或替換一個(gè)與正則表達(dá)式匹配的子串,這篇文章主要介紹了JS 將字符串中指定字符全局替換,需要的朋友可以參考下
    2023-07-07
  • js實(shí)現(xiàn)純前端的圖片預(yù)覽

    js實(shí)現(xiàn)純前端的圖片預(yù)覽

    這篇文章主要介紹了js實(shí)現(xiàn)純前端的圖片預(yù)覽的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-04-04
  • 詳解JavaScript數(shù)組的常用方法

    詳解JavaScript數(shù)組的常用方法

    這篇文章主要為大家介紹了JavaScript數(shù)組的常用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • js實(shí)現(xiàn)鼠標(biāo)移入移出卡片切換內(nèi)容

    js實(shí)現(xiàn)鼠標(biāo)移入移出卡片切換內(nèi)容

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)鼠標(biāo)移入移出卡片切換內(nèi)容,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 教你如何寫出可維護(hù)的JS代碼

    教你如何寫出可維護(hù)的JS代碼

    在平時(shí)工作開發(fā)中,大部分開發(fā)人員都花費(fèi)大量的時(shí)間在維護(hù)其他人員的代碼。很難從頭開始開發(fā)新代碼,很多情況下都是以他人成果為基礎(chǔ)的,或者新增修改需求,自己寫的代碼也會(huì)被其他開發(fā)人員調(diào)用,所以寫好一份高質(zhì)量可維護(hù)的代碼就顯得十分重要。
    2021-05-05
  • MvcPager分頁控件 適用于Bootstrap

    MvcPager分頁控件 適用于Bootstrap

    這篇文章主要為大家詳細(xì)介紹了MvcPager分頁控件,修改后適用于Bootstrap,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • webpack DllPlugin xxx is not defined解決辦法

    webpack DllPlugin xxx is not defined解決辦法

    這篇文章主要介紹了webpack DllPlugin xxx is not defined解決辦法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • javascript getElementsByClassName 和js取地址欄參數(shù)

    javascript getElementsByClassName 和js取地址欄參數(shù)

    為了從一大堆HTML代碼中找出我們的樹狀菜單(也許有多個(gè)),我們先來實(shí)現(xiàn)一個(gè)通過className找DOM節(jié)點(diǎn)的方法:getElementsByClassName。這是對(duì)瀏覽器自有DOM方法的一個(gè)簡(jiǎn)單但實(shí)用的擴(kuò)充。
    2010-01-01
  • 詳解微信小程序開發(fā)之城市選擇器 城市切換

    詳解微信小程序開發(fā)之城市選擇器 城市切換

    這篇文章主要介紹了詳解微信小程序開發(fā)之城市選擇器 城市切換,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。
    2017-01-01

最新評(píng)論