用(bootstrap)Handsontable做表格,手动实现数据排序
商品graph帐票时,用(bootstrap)Handsontable做表格,手动实现数据排序
待解决的问题:
若使用控件本身的排序,必须指定colHead,colHead不能被copy,若想表头被copy,只隐藏一行表头数据是行不通的,因为排序的时候表头数据会被排了
解决的大概思路
给数据中的第一行加上click事件,点击实现排序,排序过的数组,用控件重新加载成表格,hot.loadData(data);
不设置表头,将表头表示为第一行数据。
在定义的第一行的渲染函数中,给该行数据绑定事件:bind.(“click”,function(){...})
其中遇到的问题:
1.关于值传递。object1=object2,这样之后,不是将object2中的值复制一份给object1,而是将object2的地址给了object1一份,这样操作object1时即在操作object2,里面的内容会发生改变。
解决办法:dataTmp=JSON.parse(JSON.stringify(src.Rows));
将对象或者数组先转换成字符串JSON.stringfy,再由JSON.parse方法转换为json对象,复制给另一个对象内容,不是源对象的地址
2.每一次bind一个事件的时候,避免出现绑定的一个事件执行多次(说明多次绑定了)
解决办法:应该在每次绑定前确保该对象没有该类绑定事件$(td).off("click");
先解除绑定(不用判断是否有绑定),再绑定
var collen=0; //数据列数
for (var i=0;;i++) {
if (datashow.Rows[0]["F"+i]){
collen++;
}else {
break;
}
} var data={};
var arr=[];
for (var j=0;j<datashow.Rows.length;j++){
var tmpobj={};
for (var i=0;i<collen-1;i++) {//去掉元数据中的第3列
if (i<2){
// dataTmp2[j]["F"+i]=dataTmp[j]["F"+i]
tmpobj["F"+i]=datashow.Rows[j]["F"+i];
}else {
// dataTmp2[j]["F"+i]=dataTmp[j]["F"+(i+1)]
tmpobj["F"+i]=datashow.Rows[j]["F"+(i+1)];
}
}
arr.push(tmpobj);
}
data["Rows"]=arr;
copyDatatmp=data.Rows; var flg={"F0":2,"F2":2,"F3":2,"F8":2};
//表头渲染函数--手动添加排序功能
var headRenderer = function(instance, td, row, col, prop, value, cellProperties) {
Handsontable.renderers.TextRenderer.apply(this, arguments);
td.style.backgroundColor = '#00619C';
td.style.color = '#FFFFFF';
td.style.textAlign="center";
td.style.verticalAlign="middle";
td.style.overflow = 'hidden';
td.style.whiteSpace = 'nowrap';
td.style.textOverflow = 'ellipsis';
if (col==0||col==2) {//给1,2列加上排序功能
if (flg["F"+col]==2) {//0,1,2--数据状态 2数据原来的顺序,1数据增序,0数据减序
$(td).append("<span class='sortAble' style='background-image:url("+"images/icon/icon-sortable.png"+");background-repeat: no-repeat;background-position-y: 3px;background-position-x: 3px;'> </span>");
}else if(flg["F"+col]==0){
。。。
} else {
。。。
}
$(td).off("mouseover");//先解绑,后绑定
$(td).off("click");//
$(td).bind("mouseover",function(e){
this.style.cursor='pointer';
}); $(td).bind("click",function(e){
if (flg["F"+col]==2){
flg["F"+col]=0;
sortByCol(dataTmp,col,0);
} else if(flg["F"+col]==0){
。。。
} else {
。。。
}
return;
});
}
}
};
sortByCol=function(dataTmp,col,order) {//自定义一个排序函数
var dataTmp1=JSON.parse(JSON.stringify(dataTmp));//用数据的备份排序
if (order!=2) {
var name="F"+col;
dataTmp1.sort(byCol(name,order));
}
var allDataTmp = getAllData(headp, dataTmp2.Rows);
delete allDataTmp[0]["F"+collen];//删除 js对象中的某一个属性 pro={F1:1,F2:2} 删除F1--> delete pro["F1"] hot.loadData(allDataTmp);//重新加载handsontable的表格数据
} function byCol(propertyName,order) { //自定义的sort函数
return function(object1, object2){
var val1 = object1[propertyName];
var val2 = object2[propertyName];
// var reg = new RegExp("^[0-9]*$");
var reg = /^-?\d+\.?\d*$/;
var value1,value2;
if (reg.test(val1)&& reg.test(val2)){
value1=parseFloat(val1);
value2=parseFloat(val2);
}else {
value1=val1;
value2=val2;
}
if(order==0) {
if (value1 < value2){
return -1;
}else if (value1 > value2){
return 1;
}else {
return 0;
}
}else {
if (value1 > value2){
return -1;
}else if (value1 < value2){
return 1;
}else {
return 0;
}
}
}
}
var sumRenderer = function(instance, td, row, col, prop, value, cellProperties) {
Handsontable.renderers.TextRenderer.apply(this, arguments);
td.title = value;
if (mode==0&&outtype==0) {
if (col>3){
td.innerText = toMoney(value);
td.style.textAlign="right";
}else {
td.innerText = "合計";
td.style.textAlign="center";
}
td.style.fontWeight="bold";
}else if(mode==0&&outtype==1){
if (col>2){
td.innerText = toMoney(value);
td.style.textAlign="right";
}else {
td.innerText = "合計";
td.style.textAlign="center";
}
td.style.fontWeight="bold";
} td.style.color = '#000000'; td.style.verticalAlign="middle";
td.style.overflow = 'hidden';
td.style.whiteSpace = 'nowrap';
td.style.textOverflow = 'ellipsis'; };
// var n=0; var dataRenderer = function(instance, td, row, col, prop, value, cellProperties) {
Handsontable.renderers.TextRenderer.apply(this, arguments);
var key="R"+row;
//var d=data.Rows[row];
var d=instance.getData()[row];
if (mode>0&&d["F6"].indexOf("退")>-1) {
td.style.backgroundColor = '#AAAAAA';
} td.title = value;
if (mode==1&&col>7) {
if (value.indexOf("_")>0) {
td.innerText = toMoney(value.split("_")[0]);
}else {
td.innerText = toMoney(value);
}
}
td.style.color = '#000000';
td.style.verticalAlign="middle";
td.style.overflow = 'hidden';
td.style.whiteSpace = 'nowrap';
td.style.textOverflow = 'ellipsis';
}; $('#grid').empty();
h = document.documentElement.clientHeight - 220;
$('#grid').css("height",h);
var container = document.getElementById('grid');
var mergeCell={};
var fozenCol=0;
if (mode==0&&outtype==0) {
mergeCell={row: 1, col: 0, rowspan: 1, colspan:4};
fozenCol=4;
}else if(mode==0&&outtype==1){
mergeCell={row: 1, col: 0, rowspan: 1, colspan:3};
fozenCol=3;
}else {
fozenCol=9;
}
hot = new Handsontable(container, {
data:data.Rows,
fixedRowsTop: 1,
fixedColumnsLeft: fozenCol,
autoColumnSize:true,
fillHandle:true,
// colHeaders:colHeadersflg, currentRowClassName: 'currentRow',
cell: [
{row: 0, col: 0, className: "htMiddle"} //居中
],
cells: function (row, col, prop) {
var cellPropertiess = {};
if(row==0){
cellPropertiess.renderer = headRenderer;
}else if(mode==0&&row==1){
cellPropertiess.renderer = sumRenderer;
}else {
cellPropertiess.renderer = dataRenderer;
}
cellPropertiess.readOnly = true;
return cellPropertiess;
},
mergeCells: [mergeCell]
});
init(mode,outtype);
用(bootstrap)Handsontable做表格,手动实现数据排序的更多相关文章
- 【Bootstrap】 bootstrap-table表格组件
[Bootstrap-table] 顾名思义,这个组件专注于bootstrap风格的表格的设计,并且提供了很多表格的基础和进阶的功能,给我们开发前端的表格省下很多力气. 本文主要参考这位博主的系列文章 ...
- 读取Excel表格日期类型数据的时候
用POI读取Excel数据:(版本号:POI3.7) 1.读取Excel 2.Excel数据处理: Excel存储日期.时间均以数值类型进行存储,读取时POI先判断是是否是数值类型,再进行判断转化 1 ...
- ajax异步获取数据后动态向表格中添加数据(行)
因为某些原因,项目中突然需要做自己做个ajax异步获取数据后动态向表格中添加数据的页面,网上找了半天都没有 看到现成的,决定自己写个例子 1.HTML页面 <!doctype html> ...
- 爬取表格类网站数据并保存为excel文件
本文转载自以下网站:50 行代码爬取东方财富网上市公司 10 年近百万行财务报表数据 https://www.makcyun.top/web_scraping_withpython6.html 主要学 ...
- 【JAVA】JSP+layui框架 静态表格转化成数据表格
<table lay-filter="demo" class="layui-table" id="excTable"> < ...
- Vue电商后台管理系统项目第2天-首页添加表格动态渲染数据&分页
0x01.使用Github学习的姿势 基于昨天的内容,今天的内容需要添加几个单文件组件,路由文件也需要做相应的增加,今天重点记录使用Element-UI中的表格组件实现数据动态渲染的实现流程和分页功能 ...
- 在MVC模式下通过Jqgrid表格操作MongoDB数据
看到下图,是通过Jqgrid实现表格数据的基本增删查改的操作.表格数据增删改是一般企业应用系统开发的常见功能,不过不同的是这个表格数据来源是非关系型的数据库MongoDB.nosql虽然概念新颖,但是 ...
- 从excel表格加载数据返回DataSet
添加命名空间:using System.Data.OleDb; /// <summary> /// 从excel表格加载数据返回DataSet /// </summary> / ...
- 用div加css做表格去掉外围边框
通过div做表格时想加上边框,并且想取点外围边框: <div class="cont"> <div class="row"> <a ...
随机推荐
- 老笔记本装xubuntu+win7
https://www.freezhongzi.info/?p=167 1 install xubuntu 分区如下 sda1 20g ext4 / sda2 80g ext4 /data sda3 ...
- JAVA StringBuffer的用法
在使用StringBuffer 的时候,习惯性的像String一样把他初始化了 StringBuffer result = null; 结果警告:Null pointer access: The va ...
- 正交矩阵、正规矩阵和酉矩阵(转自Ramble Over The Cloud~)
网址:http://blog.csdn.net/alec1987/article/details/7414450 在数学中,正规矩阵 是与自己的共轭转置交换的复系数方块矩阵,也就是说, 满足 其中 是 ...
- Selenium入门6 操作元素,获取元素属性
取元素的text,属性get_attribute,标签名tag_name 操作元素:send_keys输入,click点击,submit提交,clear清除输入 状态判断:is_display,is_ ...
- Codeforces 758D Ability To Convert(区间DP)
题目链接:http://codeforces.com/problemset/problem/758/D 题意:一个n进制下的数k,其中k不会用字母,如果有A就用10代替了.求k这个数对应的,在10进制 ...
- 判断团队适不适合使用node
1.要不要用 2.历史包袱 3.跟进升级 看完scott创业公司使用node,对于一个团队要不要使用node,第一个就是如果承接的项目有很多历史迭代,线上也在稳定的抛,不要轻易的替换,比如很多老代码, ...
- 抽象类和final
抽象类: 概念:在继承过程中,形成一个继承金字塔,位于金字塔底部的类越来越具体(强大),位于塔顶的越来越抽象(简单). 关键字 :abstract 抽象类特性: [1]抽象类过于抽象,实例化后无语义 ...
- 【转】批处理命令 For循环命令详解!
批处理for命令详解FOR这条命令基本上都被用来处理文本,但还有其他一些好用的功能!看看他的基本格式(这里我引用的是批处理中的格式,直接在命令行只需要一个%号)FOR 参数 %%变量名 IN (相关文 ...
- Windows Thin PC(7月2日发布)下载+激活+汉化
在7月2日Windows 7 瘦身版Windows Thin PC(WinTPC)完成了RTM版的编译开发,WinTPC是一个面向企业用户的产品,主要面向虚 拟桌面基础架构(VDI)消费者,Win ...
- 第38章 I2S—音频播放与录音输入—零死角玩转STM32-F429系列
第38章 I2S—音频播放与录音输入 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/ ...