商品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);