首页 > 代码库 > EasyUI DataGrid 中字段 formatter 格式化不起作用
EasyUI DataGrid 中字段 formatter 格式化不起作用
今天用 EasyUI datagrid 来做列表,要对一些数据进行格式化,判断某字段状态时,发现 formatter 格式化对应的函数不起作用。
<table id="list_data" title="未审核报表" class="easyui-datagrid" style="width: auto;height:350px;" url="" toolbar="#toolbar" pagination="true" pagesize="10" total="20" rownumbers="true" fitcolumns="true" singleselect="true" pagelist="[10,20]" loadmsg="正在努力加载数据,请稍后..."> <thead> <tr> <th data-options="field:‘报表名称‘,width:200,align:‘center‘">报表名称</th> <th data-options="field:‘报表分组‘,width:80,align:‘center‘">报表分组</th> <th data-options="field:‘报表类型‘,width:80,align:‘center‘">报表类型</th> <th data-options="field:‘报表分类‘,width:80,align:‘center‘">报表分类</th> <th data-options="field:‘制表人‘,width:80,align:‘center‘">上报人</th> <th data-options="field:‘实际报出日期‘,width:90,align:‘center‘" formatter="ChangeDateFormat">上报时间</th> <th data-options="field:‘填报单位‘,width:80,align:‘center‘">上报单位</th> <th data-options="field:‘审核状态‘,width:80,align:‘center‘">审核状态</th> <th data-options="field:‘审核状态‘,width:80,align:‘center‘" formatter="managerstr">操作</th> </tr> </thead> </table>
<th data-options="field:‘审核状态‘,width:80,align:‘center‘" formatter="managerstr">操作</th>
改成 ,前面不出现过得字典
<th data-options="field:‘用户报表编号‘,width:80,align:‘center‘" formatter="managerstr">操作</th>后来检查发现 : 如果某列的 field值,在前面已经出现过,则后出现的同field列,在这里,我的是 “审核状态”,将按第一次出现的field列使用。如果第一次出现的field同值的列没有formatter,后续的formatter将无效。
处理办法,function(value,rowData,rowIndex) 第二个参数rowData.属性名访问、
function managerstr(value,rowData,rowIndex) { if (rowData["审核状态"] == "未审核") return "1"; else if (rowData["审核状态"] == "已取回重填") return "2"; else return "已经审核,不允许操作"; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。