Webix:自定义页脚数据过滤器
Webix: custom footer datafilter
我正在使用树表并实现了自定义数据过滤器。我只想在数据层次结构的第一级进行一些操作。你知道我怎么做吗?
我会告诉你一些背景。在下面的 gif 中,当我单击打开数据的内部级别时,总和(或平均值)发生变化。高层算错了一次这个信息
我只需要放一个条件,就是一级make something
这是我当前的代码。
<script>
webix.ui.datafilter.reports = {
refresh: function(master, node, column){
trackCells:false,
refresh: function(master, node, column){
var result = 0;
var tipoDeDados = null;
master.mapCells(null, column.columnId, null, 1, function(value){
if (tipoDeDados === null) {
tipoDeDados = defineTipoDeDados(value);
}
valorLimpo = removeCaracteresInvalidos(value);
result += valorLimpo; // here I think that I need the condition
return value;
});
if (tipoDeDados === "porcentagem") {
node.firstChild.innerHTML = (result/master.count()).toFixed(2).replace('.', ',') + '%';
} else if (tipoDeDados === "moeda") {
node.firstChild.innerHTML = 'R$ ' + (result).toFixed(2).replace('.', ',');
} else if (tipoDeDados === "numerico") {
node.firstChild.innerHTML = result;
} else {
node.firstChild.innerHTML = "";
}
},
render: function(a, b){}
};
</script>
Webix 文档说我只需要将 trackCells 设置为 false 以避免重新加载数据过滤器,但是当我通过 ajax 加载获得新数据时它不起作用。
使用下面的代码我得到了我想要的结果。
webix.ui.datafilter.reports = {
trackCells:false,
refresh: function(master, node, value){
var result = 0;
var numberCellsAtFirstLevel = 0;
var tipoDeDados = null;
master.data.each(function(obj) {
currentValue = obj[value.columnId];
if (tipoDeDados === null) {
tipoDeDados = defineTipoDeDados(currentValue);
}
valorLimpo = removeCaracteresInvalidos(currentValue);
if (obj.$level == 1) {
result += valorLimpo;
numberCellsAtFirstLevel += 1
}
return currentValue;
});
if (tipoDeDados === "porcentagem") {
node.firstChild.innerHTML = (result/numberCellsAtFirstLevel).toFixed(2).replace('.', ',') + '%';
} else if (tipoDeDados === "moeda") {
node.firstChild.innerHTML = 'R$ ' + (result).toFixed(2).replace('.', ',');
} else if (tipoDeDados === "numerico") {
node.firstChild.innerHTML = result;
} else {
node.firstChild.innerHTML = "";
}
},
render: function(a, b){}
};
我正在使用树表并实现了自定义数据过滤器。我只想在数据层次结构的第一级进行一些操作。你知道我怎么做吗?
我会告诉你一些背景。在下面的 gif 中,当我单击打开数据的内部级别时,总和(或平均值)发生变化。高层算错了一次这个信息
我只需要放一个条件,就是一级make something
这是我当前的代码。
<script>
webix.ui.datafilter.reports = {
refresh: function(master, node, column){
trackCells:false,
refresh: function(master, node, column){
var result = 0;
var tipoDeDados = null;
master.mapCells(null, column.columnId, null, 1, function(value){
if (tipoDeDados === null) {
tipoDeDados = defineTipoDeDados(value);
}
valorLimpo = removeCaracteresInvalidos(value);
result += valorLimpo; // here I think that I need the condition
return value;
});
if (tipoDeDados === "porcentagem") {
node.firstChild.innerHTML = (result/master.count()).toFixed(2).replace('.', ',') + '%';
} else if (tipoDeDados === "moeda") {
node.firstChild.innerHTML = 'R$ ' + (result).toFixed(2).replace('.', ',');
} else if (tipoDeDados === "numerico") {
node.firstChild.innerHTML = result;
} else {
node.firstChild.innerHTML = "";
}
},
render: function(a, b){}
};
</script>
Webix 文档说我只需要将 trackCells 设置为 false 以避免重新加载数据过滤器,但是当我通过 ajax 加载获得新数据时它不起作用。
使用下面的代码我得到了我想要的结果。
webix.ui.datafilter.reports = {
trackCells:false,
refresh: function(master, node, value){
var result = 0;
var numberCellsAtFirstLevel = 0;
var tipoDeDados = null;
master.data.each(function(obj) {
currentValue = obj[value.columnId];
if (tipoDeDados === null) {
tipoDeDados = defineTipoDeDados(currentValue);
}
valorLimpo = removeCaracteresInvalidos(currentValue);
if (obj.$level == 1) {
result += valorLimpo;
numberCellsAtFirstLevel += 1
}
return currentValue;
});
if (tipoDeDados === "porcentagem") {
node.firstChild.innerHTML = (result/numberCellsAtFirstLevel).toFixed(2).replace('.', ',') + '%';
} else if (tipoDeDados === "moeda") {
node.firstChild.innerHTML = 'R$ ' + (result).toFixed(2).replace('.', ',');
} else if (tipoDeDados === "numerico") {
node.firstChild.innerHTML = result;
} else {
node.firstChild.innerHTML = "";
}
},
render: function(a, b){}
};