对于layui的table插件无法多层级获取json数据的解决方法,版本:2.2.6
根据官方文档 你接口返回的数据格式,遵循 response 对应的字段名称。
默认的格式为如下:
- {
- code: 0,//数据状态的字段名称,默认:code
- msg: “”, //状态信息的字段名称,默认:msg
- count: 1000,//数据总数的字段名称,默认:count
- data: []//数据列表的字段名称,默认:data
- }
那么当后台返回的数据为如下格式时:就无法直接获取到“list”和“total”了
- {“status”:0,
- “msg”:”超级管理员查询成功”,
- “data”:{
- “pageNum”:1,
- “pageSize”:10,
- “size”:2,
- “total”:2,
- “list”:[
- {“phone”:”13713596448”,”username”:”旺”,”passwd”:”1”,”usegrant”:”0”,”leader”:”“,”chancecount”:”1000”,”createtime”:1528369281000,”updatetime”:1528369285000,”usecount”:”0”},
- {“phone”:”18038060732”,”username”:”彬”,”passwd”:”1”,”usegrant”:”0”,”leader”:”“,”chancecount”:”100”,”createtime”:1528422270000,”updatetime”:1528422270000,”usecount”:”0”}
- ]
解决方案:
1. 最直接的方法是叫后台人员直接改为官方文档的方式
2. 先通过ajax获取到数据,然后通过data属性进行赋值,当涉及到分页时,代码会比较冗余;
3.通过url属性赋值,则在table源文件中 M.prototype.page方法下添加以下代码:
- var multilevel=function (data,list) {
- var d = data;
- for (var i in list){
- d =d[list[i]];
- }
- return d
- };
- var renderResponse=function (data) {
- var statusNameLsit=r.statusName.split("."),
- msgNameLsit=r.msgName.split("."),
- countNameLsit=r.countName.split("."),
- dataNameLsit=r.dataName.split(".");
- var dataTemp={};
- dataTemp[r.statusName]=multilevel(data,statusNameLsit);
- dataTemp[r.msgName]=multilevel(data,msgNameLsit);
- dataTemp[r.countName]=multilevel(data,countNameLsit);
- dataTemp[r.dataName]=multilevel(data,dataNameLsit);
-
- return dataTemp;
- };
在M.prototype.page中ajax请求成功函数success里添加以下代码:
- typeof renderResponse === 'function' && (t = renderResponse(t));
使用时:在response属性中用.来分割层级,代码如下:
- response: {
- statusName: 'status' //数据状态的字段名称,默认:code
- ,statusCode: 0 //成功的状态码,默认:0
- ,msgName: 'msg' //状态信息的字段名称,默认:msg
- ,countName: 'data.total' //数据总数的字段名称,默认:count
- ,dataName: 'data.list' //数据列表的字段名称,默认:data
- }
以上这篇解决layui的table插件无法多层级获取json数据的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持w3xue。