kendo grid表格加载完成之后触发事件dataBound
来源:互联网 发布:淘宝手机下单减价 编辑:程序博客网 时间:2024/05/30 23:43
今天在做表格显示时 需要在kendo grid表格生成之后根据其中一个字段的值进行整列的渲染(底部颜色不同),显示图片如下:
在表格生成之后调用其获取其行的数据,在得到相应的字段值进行判断然后给予相应的css样式,但建立的前提在此事件必须在表格加载完成之后才能触发。这样一遍获取到相应的参数,使用了window.onload 方法结果不行 ,在表格没加载完成之前就执行了,最终找到了kendo 中的一个dataBound属性(表格加载完成后执行)完美的解决的这个问题。
未添加之前效果图:
代码如下:
//获取远程的数据 var _dbopt = { transport: { read: { url: “远程数据的url”, type: "POST", dataType: "json", cache: false, //提交form表单进行序列化提交 data: function (p) { if (formId) { var arr = $(formId).serializeArray(); $(formId).serializeArray(); if (arr && arr.length > 0) { var d = {}; $.each(arr, function (idx, it) { if (it.value) { // 多选情况下,同一key有多个值 if (d[it.name]) { d[it.name] = d[it.name] + ","+it.value; } else{ d[it.name] = it.value; } } }); return d; } } return {}; } }, parameterMap: function (data, type) { if (type == "read") { data.pageNo = data.page; data.page = undefined; data.take = undefined; data.skip = undefined; delete data.page; delete data.take; delete data.skip; return data; } } }, schema: { type: "json", data: "rows", total: "total" }, serverPaging: true, pageSize: options.pageSize || 20, change: function () { _constants.DATA_GRID_NUMBER_START = 0; } };var columns = [ { field: "sbbh", hidden:true }, { field:"hphm", title: "号牌号码", template:function (dateItem) { return "<span>"+dateItem.hphm+"</span>" }, width:100 }, { field: "wfdz", title:"违法地址", template:function (dateItem) { return "<span>"+dateItem.wfdz+"</span>" }, width:200 }, { field: "wfsj", title: "违法时间", template:function (dateItem) { return "<span>"+dateItem.wfsj+"</span>" }, width:130, //attributes: {style: "#= 'color:red;' #"} }, { field:"isCheck", title: "状态", width: 70, template:function (dateItem) { if(dateItem.isCheck == 0){ return "<span>未处理</span>" }else if(dateItem.isCheck == 1){ return "<span style='color: #FFC414'>已校对</span>" }else if(dateItem.isCheck == 2){ return "<span style='color: green'>已审核</span>" }else if(dateItem.isCheck == 3){ return "<span style='color: green' >上传成功</span>" }else if(dateItem.isCheck == 4){ return "<span onclick='addColor()' style='color: #e00f0f'>已作废</span>" }else if(dateItem.isCheck == 5){ return "<span style='color: #FB6D17'>审核作废</span>" }else if(dateItem.isCheck == 6){ return "<span style='color: red'>上传失败</span>" } } }, { field: "zfyy", title: "备注", template:function (dateItem) { return "<span>"+dateItem.zfyy+"</span>" }, width:180 } ]//调用kendo ui 的配置项 var _opt = { dataSource: new kendo.data.DataSource(_dbopt), toolbar: hc.template($(toolbarId).html().replace(/</g, '<').replace(/>/g, '>')), height: "100%", groupable: false, selectable: true, pageable: { refresh: true, pageSizes: [10, 20, 50, 100], input: (showShort==true?false:true), buttonCount: (showShort==true?1:5), messages: { empty: "没有数据", display: (showShort==true?"":"共{2}条数据,本页显示{0}-{1}条"), page: "", of: "/ {0}", itemsPerPage: "", first: "首页", last: "末页", next: "下一页", previous: "上一页", refresh: "刷新", morePages: "更多页" } }, showNumber: true, columns: columns, dataBound:addColor //在这里添加一个dataBound属性 在表格加载完成后执行 addColor方法 sortable: { mode: "multiple", allowUnsort: true //允许不分类 }, resizable: false, selectable: "multiple,row", showNumber:true //展示序号列 }; //kendo表格加载完成后触发事件 function addColor(){ var grid = $("#grid").data("kendoGrid"); // 行样式 var rows = grid.tbody.find("tr"); rows.each(function (i, row) { var isCheck = $(this).find("td>span").eq(3).text(); if(isCheck == '上传成功'){ $(this).css("background-color", "#d1edb8"); }; }); }
主要代码在倒数23行左右 “dataBound:addColor” 来完成加载完成后触发事件
效果图如下:
阅读全文
0 0
- kendo grid表格加载完成之后触发事件dataBound
- AngularJS加载完成之后触发事件
- kendo Grid加载远程数据方式
- kendo.ui.Grid绑定单双击事件
- jQuery-iframe加载完成后触发的事件监听
- jQuery页面加载时触发ready()事件 dom结构加载完成就触发。(参考慕课网)
- jquery DOM加载完成之后立即执行js事件
- Extjs grid 及触发事件
- kendo dataBound 单元格内部分变色
- Kendo UI Grid结合Window完善Custom事件
- 代码触发表格编辑事件
- 页面加载完成之后执行
- ComponentArt Grid触发和处理服务器端事件
- Ext Grid上双击触发事件
- repeater 的另外一种用法,不一定需要在databound加载事件
- iframe加载完成事件
- kendo ui grid 汉化
- MVC kendo Grid EditorTemplate
- HDU 6119 小小粉丝度度熊【尺取法】
- HTML5-调用-购物车商品(del)-班级添加-也买酒
- 16、图
- java基础学习总结——面向对象1
- 数据库详解
- kendo grid表格加载完成之后触发事件dataBound
- 图的深度优先遍历和广度优先遍历
- LRCN(1)
- 打靶
- 练习 2017-8-14 缓冲字节/字符 输入/输出 流~ 字符的编码和解码
- MySQL 的redo 和 undo
- [Linux] yum和apt-get用法及区别
- STL中next_permutation函数快速上手
- github使用教程与问题解决