欧美一级视-欧美一级视频高清片-欧美一级视频免费-欧美一级视频免费观看-午夜激情视频在线播放-午夜激情视频在线观看

咨詢電話:
15628812133
19
2019/12

layui如何合并數(shù)據(jù)表格

發(fā)布時(shí)間:2019-12-19 17:22:05
發(fā)布者:會(huì)飛的魚
瀏覽量:
0

layui作為一款現(xiàn)在非常流行的UI框架,相信很多的小伙伴們都用過吧。其中的數(shù)據(jù)表格在前端調(diào)用中,更是節(jié)省了不少重復(fù)書寫獲取設(shè)置接口數(shù)據(jù)的時(shí)間,但是有些情況單靠官方的檔案還是無法滿足我們的工作需求的,如何并單元格一類的操作,官方檔案中只有表頭合并的操作文檔,但是我們遇到更多的是表格內(nèi)部的合并,今天文匯軟件小編就來為大家分享下這方面的心得。

如下圖所示:

這是一份病人的手術(shù)用藥單,大部分的病人取藥可能到要好幾種,但是如果用官方文檔他原來的數(shù)據(jù)表格就會(huì)像下圖。即使是相同的病人也會(huì)用很多不同條數(shù)的信息,病人的信息很多在瀏覽時(shí)很不方便。

1.jpg

小編說實(shí)話一開始也很懵,后來在網(wǎng)上找到了關(guān)于layui的高手。他的大體思路應(yīng)該是:這個(gè)應(yīng)該先是獲取td中所有的數(shù)量,然后獲取每個(gè)td的值,然后再獲取下個(gè)tr中相同位置的td值如果值相同,時(shí)期合并并獲取父級(jí)tr的高度,同時(shí)除了他之外的其他td都隱藏,代碼如下:

 layui.use('table', function(){

        var table = layui.table;

        table.reload('test2', {

           url: '',//你的接口

           done: function(res, curr, count){

            console.log(res);

            layuiRowspan(['fname','PATIENT_NAME','PATIENT_MRN','PATIENT_SEX','age'],1);

            layuiRowspan(res.data,1);//支持?jǐn)?shù)組

            layuiRowspan(count,1,true);

          }

        });

    });

}


var execRowspan = function(fieldName,index,flag){

  // 1為不凍結(jié)的情況,左側(cè)列為凍結(jié)的情況

  let fixedNode = index=="1"?$(".layui-table-body")[index - 1]:(index=="3"?$(".layui-table-fixed-r"):$(".layui-table-fixed-l"));

  // 左側(cè)導(dǎo)航欄不凍結(jié)的情況

  let child = $(fixedNode).find("td");

  let childFilterArr = [];

  // 獲取data-field屬性為fieldName的td

  for(let i = 0; i < child.length; i++){

    if(child[i].getAttribute("data-field") == fieldName){

      childFilterArr.push(child[i]);

    }

  }

  // 獲取td的個(gè)數(shù)和種類

  let childFilterTextObj = {};

  for(let i = 0; i < childFilterArr.length; i++){

    let childText = flag?childFilterArr[i].innerHTML:childFilterArr[i].textContent;

    if(childFilterTextObj[childText] == undefined){

      childFilterTextObj[childText] = 1;

    }else{

      let num = childFilterTextObj[childText];

      childFilterTextObj[childText] = num*1 + 1;

    }

  }

  let canRowspan = true;

  let maxNum;//以前列單元格為基礎(chǔ)獲取的最大合并數(shù)

  let finalNextIndex;//獲取其下第一個(gè)不合并單元格的index

  let finalNextKey;//獲取其下第一個(gè)不合并單元格的值

  for(let i = 0; i < childFilterArr.length; i++){

    (maxNum>9000||!maxNum)&&(maxNum = $(childFilterArr[i]).prev().attr("rowspan")&&fieldName!="8"?$(childFilterArr[i]).prev().attr("rowspan"):9999);

    let key = flag?childFilterArr[i].innerHTML:childFilterArr[i].textContent;//獲取下一個(gè)單元格的值

    let nextIndex = i+1;

    let tdNum = childFilterTextObj[key];

    let curNum = maxNum

    if(canRowspan){

      for(let j =1;j<=curNum&&(i+j

        finalNextKey = flag?childFilterArr[i+j].innerHTML:childFilterArr[i+j].textContent;

        finalNextIndex = i+j;

        if((key!=finalNextKey&&curNum>1)||maxNum == j){

          canRowspan = true;

          curNum = j;

          break;

        }

        j++;

        if((i+j)==childFilterArr.length){

          finalNextKey=undefined;

          finalNextIndex=i+j;

          break;

        }

      }

      childFilterArr[i].setAttribute("rowspan",curNum);

      if($(childFilterArr[i]).find("div.rowspan").length>0){//設(shè)置td內(nèi)的div.rowspan高度適應(yīng)合并后的高度

        $(childFilterArr[i]).find("div.rowspan").parent("div.layui-table-cell").addClass("rowspanParent");

        $(childFilterArr[i]).find("div.layui-table-cell")[0].style.height= curNum*38-10 +"px";

      }

      canRowspan = false;

    }else{

      childFilterArr[i].style.display = "none";

    }

    if(--childFilterTextObj[key]==0|--maxNum==0|--curNum==0|(finalNextKey!=undefined&&nextIndex==finalNextIndex)){//||(finalNextKey!=undefined&&key!=finalNextKey)

      canRowspan = true;

    }

  }

}

//合并數(shù)據(jù)表格行

var layuiRowspan = function(fieldNameTmp,index,flag){

  let fieldName = [];

  console.log(fieldNameTmp,index,flag);

  if(typeof fieldNameTmp == "string"){

    fieldName.push(fieldNameTmp);

  }else{

    fieldName = fieldName.concat(fieldNameTmp);

  }

  for(let i = 0;i

    execRowspan(fieldName[i],index,flag);

  }

}

結(jié)果如下圖所示:

1.jpg

這里只需要在數(shù)據(jù)表格渲染的時(shí)候改成自己的東西即可,其他的內(nèi)容說實(shí)話有些復(fù)雜,有能開發(fā)出更多用法的小伙伴歡迎聯(lián)系文匯軟件小編,小編在這里等你哦???

返回列表
精品视频在线观看免费| 黄视频网站免费看| 国产一级强片在线观看| 夜夜操网| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 美国一区二区三区| 欧美电影免费看大全| 青青久在线视频| 日韩av成人| 欧美日本免费| 精品国产一区二区三区国产馆| 亚洲精品中文字幕久久久久久| 日日爽天天| 日韩欧美一二三区| 天堂网中文字幕| 韩国三级视频在线观看| 精品久久久久久中文| 成人免费观看男女羞羞视频| 999久久久免费精品国产牛牛| 91麻豆精品国产综合久久久| 久久精品欧美一区二区| 国产成人精品综合| 精品在线观看国产| 日本特黄特色aaa大片免费| 欧美国产日韩一区二区三区| 香蕉视频久久| 人人干人人插| 日本伦理黄色大片在线观看网站| 日韩一级黄色片| 久久久久久久免费视频| 国产一区二区精品尤物| 精品国产一区二区三区久| 91麻豆精品国产综合久久久| 天天做日日爱| 成人在免费观看视频国产| 日韩一级黄色大片| 欧美激情中文字幕一区二区| 99久久精品国产高清一区二区| 亚洲精品久久久中文字| 成人免费高清视频| 亚洲女人国产香蕉久久精品| 精品视频在线观看一区二区三区| 亚洲精品永久一区| 黄视频网站在线看| 精品国产一区二区三区久久久蜜臀 | 国产91素人搭讪系列天堂| 成人影视在线观看| 国产精品自拍一区| 韩国三级视频网站| 成人免费高清视频| 国产不卡高清| 精品久久久久久中文| 欧美激情伊人| 999精品影视在线观看| 国产成人精品综合| 久久精品道一区二区三区| 九九九网站| 在线观看成人网| 国产视频一区二区在线观看| 美女免费黄网站| 国产一区国产二区国产三区| 精品久久久久久综合网| 免费毛片基地| 欧美日本二区| 成人影院一区二区三区| 欧美a级片免费看| 日韩专区第一页| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | a级毛片免费全部播放| 午夜欧美成人香蕉剧场| 亚洲天堂免费观看| 一本高清在线| 国产一区国产二区国产三区| 色综合久久天天综合观看| 国产福利免费视频| 97视频免费在线观看| 精品视频在线观看一区二区| 精品国产一级毛片| 黄色福利片| 欧美激情一区二区三区视频高清 | 999精品在线| 午夜在线亚洲| 成人在免费观看视频国产| 国产一区二区精品久久91| 九九免费高清在线观看视频| 国产麻豆精品视频| 国产麻豆精品hdvideoss| 国产高清在线精品一区二区| 日本特黄一级| 日韩综合| 精品视频在线看 | 日本伦理网站| 日本特黄一级| 色综合久久天天综合观看| 欧美爱色| 亚洲精品久久久中文字| 99久久精品国产高清一区二区| 日韩av东京社区男人的天堂| 日韩中文字幕在线播放| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 久久精品人人做人人爽97| 日本伦理片网站| 国产精品免费久久| 欧美激情中文字幕一区二区| 日本免费乱理伦片在线观看2018| 91麻豆精品国产自产在线| 91麻豆精品国产高清在线| 国产亚洲免费观看| 韩国三级香港三级日本三级la | 国产麻豆精品| 一本高清在线| 久久成人综合网| 二级特黄绝大片免费视频大片| 日韩一级黄色| 国产91丝袜在线播放0| 亚洲 国产精品 日韩| 久久99中文字幕| 精品毛片视频| 四虎影视久久| 久久99中文字幕| 精品国产一区二区三区精东影业 | 精品国产一区二区三区国产馆| 午夜在线亚洲| 中文字幕一区二区三区精彩视频| 一级毛片视频播放| 日本伦理片网站| 亚欧视频在线| 亚洲wwwwww| 午夜在线亚洲| 国产视频在线免费观看| 国产视频一区在线| 四虎久久精品国产| 青青青草影院| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 91麻豆精品国产高清在线| 日韩一级黄色大片| 韩国三级视频在线观看| 国产亚洲免费观看| 色综合久久手机在线| 久久福利影视| 国产精品1024在线永久免费| 999精品在线| 免费毛片播放| 精品国产亚一区二区三区| 久久国产精品永久免费网站| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 91麻豆精品国产片在线观看| 九九久久99| 毛片电影网| 久久久久久久久综合影视网| 国产麻豆精品hdvideoss| 欧美激情一区二区三区视频 | 一级女性大黄生活片免费| 精品国产香蕉伊思人在线又爽又黄| 美女被草网站| 国产网站免费| 国产视频一区二区在线观看| 日韩免费在线观看视频| 欧美大片a一级毛片视频| 高清一级淫片a级中文字幕| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 色综合久久天天综合绕观看| 日本伦理黄色大片在线观看网站| 亚飞与亚基在线观看| 日日夜夜婷婷| 91麻豆国产福利精品| 日韩在线观看视频网站| 成人a大片在线观看| 国产不卡在线观看| 深夜做爰性大片中文| 四虎影视库| 久久精品人人做人人爽97| 欧美爱色| 欧美α片无限看在线观看免费| 国产麻豆精品高清在线播放| 国产成人女人在线视频观看| 国产一区二区精品| 国产一区二区精品| 欧美爱爱网| 亚欧成人乱码一区二区| 午夜在线影院| 国产网站免费| a级毛片免费全部播放| 国产欧美精品| 精品视频一区二区三区| 欧美日本免费| 久久久久久久男人的天堂| 亚洲wwwwww| 精品国产一区二区三区免费 | 精品国产亚一区二区三区| 99热视热频这里只有精品| 欧美激情一区二区三区在线播放| 国产国语在线播放视频| 精品国产一区二区三区精东影业 | 午夜激情视频在线观看| 国产一级生活片| 国产a一级| 美女被草网站| 精品视频在线观看视频免费视频| 免费的黄视频|