用(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 ...
 
随机推荐
- 基于FPGA的VGA显示设计(二)
			
上一篇:基于FPGA的VGA显示设计(一) 参照 CrazyBingo 的 基于FPGA的VGA可移植模块终极设计代码 的工程代码风格,模块化处理了上一篇的代码,并增加了一点其它图形. 顶层 ...
 - To my dear friends in SFAE
			
To my dear friends in SFAE, 这不是farewell,我还在西门子大家庭.2018年1月份我会转到SLC MCBU.在SFAE十年,一些敢想,唠叨唠叨~ 十年弹指一挥间.记得 ...
 - IOS  设置颜色的的详情
			
- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...
 - IOS 获取.plist文件的数据
			
@property (nonatomic,strong) NSArray *apps; //获取.plist数据 /**获取plist文件的数组数据*/ -(NSArray *)apps{ if( ...
 - 奇异值分解(SVD)原理及应用
			
一.奇异值与特征值基础知识: 特征值分解和奇异值分解在机器学习领域都是属于满地可见的方法.两者有着很紧密的关系,我在接下来会谈到,特征值分解和奇异值分解的目的都是一样,就是提取出一个矩阵最重要的特征. ...
 - Docker 入门教程与实践
			
title: Docker 入门教程与实践 tags: Docker ---- 在Windows上安装Docker客户端 1.下载Docker TollBox: https://docs.docker ...
 - C#类的实例
			
一.C#类的实例 类的实例其实就是类的对象.定义类之后即可声明类的对象,声明对象之后便可以访问对象的成员了. 语法格式如下: 类名 对象名; // 声明对象对象名 = new 类名() ...
 - forEach、for...in、for...of
			
forEach 数组实例的遍历方法 const arr=['red', 'green', 'blue']; arr.forEach(function(element, index) { console ...
 - BZOJ1004: [HNOI2008]Cards(Burnside引理 背包dp)
			
Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4255 Solved: 2582[Submit][Status][Discuss] Descript ...
 - shell脚本结构化语句
			
本文中记录一下shell中的两种循环语句:for和while for循环 for循环是linux shell中最常用的结构,for循环有三种结构:1.列表for循环.2.不带列表for循环.3.C风格 ...