共计 6465 个字符,预计需要花费 17 分钟才能阅读完成。
又 get 到一种思路,不光是 layui。
外面这层 table,就是用原生拼接的。
@Override
public List<Map<String, Object>> distribution(String begin,String end,String name,String hospitalCode) {HashMap<String, Object> params = new HashMap<String, Object>();
StringBuffer buf = new StringBuffer();
List<HRateAllotDepartment> hRateAllotDepartment = rateAllotDepartmentDao.getRateDepartment(hospitalCode);
String str1 = "";
String str2 = "";
for(int i=0;i<hRateAllotDepartment.size();i++) {str1 +=",sum(`"+hRateAllotDepartment.get(i).getDepartmentName()+"`)`"+hRateAllotDepartment.get(i).getDepartmentName()+"`";
str2 +=",max(case when e.`name`='"+hRateAllotDepartment.get(i).getDepartmentName()+"'then f.price else 0 end) `"+hRateAllotDepartment.get(i).getDepartmentName()+"`";}
buf.append("select d.`name`,d.productId_,count(*) renshu,sum(price) total"+str1+" ");
buf.append("from ( SELECT b.`name`,b.id productId_ ,d.id,max(b.price) price");
buf.append(""+str2+" FROM ");
buf.append("dt_pay_health_order_product a"
+ "JOIN dt_pay_health_order d ON a.orderId = d.id"
+ "JOIN dt_pay_health_product b ON a.productId = b.id");
buf.append("JOIN dt_hospital_health_item c ON b.bizId = c.id"
+ "JOIN dt_hospital_health_order_use g ON g.orderProductId = a.id"
+ "JOIN dt_hospital_rate_allot f ON b.id = f.productId");
buf.append("JOIN dt_hospital_department e ON f.departmentId = e.id where g.createDate>=:begin and g.createDate<=:end and b.name like :name and a.state ='02'group by b.`id`,d.`id`) d group by d.productId_ WITH ROLLUP");
if(begin == null || begin.length() == 0){begin = "1970-01-01";}
if(end == null || end.length() == 0){end = "2099-01-01";}
params.put("begin",begin);
params.put("end",end);
params.put("name","%"+name+"%");
return this.getMapListByMap(buf.toString(), params);
}
可以看到,一开始是有一个 list,这个 list 是医院医生可以配置的科室,这些科室就是动态的。这样一来后台即可得到动态数据。同理,如果在 layui 时用到 page,在这里返回成 page 类型即可。接下来再看 js
function toList(begin,end,name){console.log(begin);
console.log(end);
$.ajax({
url: basePath + "/biz/hospital/rate/allot/list.do",
data: {
begin:begin,
end:end,
name:name
},
type : 'post',
dataType : 'json',
success : function(data) {var arrayPrice = new Array();
for(var i=0;i<data.length;i++){var arrayPrice1 = new Array();
for(var key in data[i]){if(key!="name"&&key!="productId_"&&key!="renshu"&&key!="total"){arrayPrice1[key]=data[i][key];
}
}
arrayPrice.push(arrayPrice1);
}
var title="";
var sumCols="";
var partCols=new Array();
for(var i=0;i<arrayPrice.length;i++){
var partColsStr = "";
for(var key in arrayPrice[i]){if(i==0&&(arrayPrice[arrayPrice.length-1][key]!=0)){title+="<th class='firstTh'>"+key+"(元)</th>";}
if(i==(arrayPrice.length-1)&&(arrayPrice[arrayPrice.length-1][key]!=0)){sumCols+="<td class='secondTd'>"+arrayPrice[i][key]+"</td>";
}
if(i!=(arrayPrice.length-1)&&(arrayPrice[arrayPrice.length-1][key]!=0)){partColsStr += "<td class='thirdTd'>"+arrayPrice[i][key]+"</td>";
}
}
partCols.push(partColsStr);
}
var sRenshu = 0;
var stotal = 0;
var tablex = "";
tablex += "<tr class='firstTr'><th class='firstTh'> 项目名称 </th><th class='firstTh'> 检查人数 </th><th class='firstTh'> 金额(元)</th>"+title+"</tr>";
if(data!=null && data.length>0){for(var i=0;i<data.length-1;i++){sRenshu+=data[i].renshu;
stotal+=data[i].total;
}
tablex += "<tr class='secondTr'><td class='secondTd'> 总计 </td><td class='secondTd'>"+sRenshu+"</td><td class='secondTd'>"+stotal+"</td>"+sumCols+"</tr>";
for(var i=0;i<data.length-1;i++){
{tablex += "<tr class='thirdTr'><td class='thirdTd'>"+data[i].name+"</td>" +
"<td class='thirdTd'>" +
"<a style='color:#ff5722'href="+basePath +"/biz/hospital/rate/allot/toPageMx.do?startDate="+$("#startDate").val().toString()
+"&endDate="+$("#endDate").val().toString()
+"&productId_="+data[i].productId_+">"+
data[i].renshu+"</a></td>" +
"<td class='thirdTd'>"+data[i].total+ partCols[i] +
"</tr>";
}
}
}
$("#table_status").empty();
$("#table_status").append(tablex);
},
error : function() {layer.msg('系统异常,请联系管理员!',{icon:2,time:2000});
}
});
}
可以在最上方图看到,有些字段是固定的,但是有些字段是动态的。思路是通过将调用接口返回出来的数据,动态的部分放到一个键值对数组下。这样一来,固定的部分,依然可以用返回的 data 得到,而动态的部分,用处理的数组循环赋值即可。动态表头就是动态数组的键。数据就是值。
if(key!="name"&&key!="productId_"&&key!="renshu"&&key!="total"){arrayPrice1[key]=data[i][key];
}
这块是 name 这些的是固定的,就排除掉,然后将数据放到 arrayPrice1 下再 push 到数组下。tablex 就是表格的 html。当时拼接的是分两步,先是表头,然后是数据。有个总计,后来在 sql 下加了 WITH ROLLUP 就得到了。
for(var key in arrayPrice[i]){
if(i==0&&(arrayPrice[arrayPrice.length-1][key]!=0)){title+="<th class='firstTh'>"+key+"(元)</th>";}
if(i==(arrayPrice.length-1)&&(arrayPrice[arrayPrice.length-1][key]!=0)){sumCols+="<td class='secondTd'>"+arrayPrice[i][key]+"</td>";
}
if(i!=(arrayPrice.length-1)&&(arrayPrice[arrayPrice.length-1][key]!=0)){partColsStr += "<td class='thirdTd'>"+arrayPrice[i][key]+"</td>";
}
}
这块就是动态的数据,title 表头,sumCols 总计,partColsStr 具体数据,加到 tablex 下就行。以上就是原生的思路。
这块 table 用到了 layui,当时也是看着这个 layui 动态设置的思路去写的原生。主要思路是:cols 是一个数组,通过 ajax 得到数据后放到数组下,再放到 cols 下即可。
$.ajax({
url: basePath + "/biz/hospital/rate/allot/department/getDepartment.do",
data: { },
type : 'post',
dataType : 'json',
success : function(data) {mycols[0] = {field : 'nameTrue', title:"姓名", align:'center',width:'120'};
mycols[1] = {field : 'telephoneTrue', title:'支付手机号', align:'center',width:'120'};
mycols[2] = {field : 'orderNO', title:'订单号', align:'center',width:'120'};
mycols[3] = {field : 'createDate', title:'订单创建时间', align:'center',width:'120'};
mycols[4] = {field : 'modifyDate', title:'订单使用时间', align:'center',width:'120'};
mycols[5] = {field : 'price', title:'支付金额(元)', align:'center',width:'120'};
for (var i = 0;i < data.length; i++){var obj = data[i].departmentName;
if(obj!=0){mycols[i+6] = {field : obj, title:obj+"(元)", align:'center',width:'120'};
}
}
console.log(mycols);
reload();},
error : function() {layer.msg('系统异常,请联系管理员!',{icon:2,time:2000});
}
});
以上是 ajax 调用后处理的数组。下面这些就是 table。reload(); 就是重新渲染。
var options = {
url: basePath + "/biz/hospital/rate/allot/list_mx.do",
method: 'post',
where:{begin:$("#startDate").val().toString(),
end:end,
productId_:$("#productId_").val().toString(),
orderNO:$("#qorderNO").val().toString(),
name:$("#qname").val().toString()
},
// 分页请求参数
request:{
pageName: 'pageIndex', // 页码
limitName: 'limit' // 每页多少数据
},
// 返回的数据格式
response:{
statusName: 'status', // 数据状态的字段名称,默认:code
statusCode: 200, // 成功的状态码,默认:0
msgName: 'message', // 状态信息的字段名称,默认:msg
countName: 'total', // 数据总数的字段名称,默认:count
dataName: 'data' // 数据列表的字段名称,默认:data
},
// 每页 10 条数据
limit: 10,
// 加载时出现加载条
loading: true,
elem: '#data_table',
cols: [mycols],
id: 'dataTable',
page: true,
};
// 方法级渲染
table.render(options);
function reload(){date = new Date($("#endDate").val());
date=date.setDate(date.getDate()+1);
date=new Date(date);
datemonth=date.getMonth()+1; // 获取当前月份 (0-11,0 代表 1 月)
end=date.getFullYear()+"-"+datemonth+"-"+date.getDate();
//options.where.departmentId = $("#departmentId").val();
options.where.begin = $("#startDate").val();
options.where.end = end;
options.where.orderNO = $("#qorderNO").val();;
options.where.name = $("#qname").val();;
table.reload("dataTable",options);
}
可以看到
cols: [mycols],
这个就是动态数据。