我在crossfilter.js上收到错误"too much recursion"
如何修复此错误。
这里我的javascript代码(我从php.So数据中提供数据没有错。我认为尺寸错误):
var data= [{
HASTANE: 'ANK',
SEHIR: 'Ankara',
BOLGE: 'İç Anadolu Bölgesi ',
KOD: 'C00',
KODACIKLAMA: 'Dudağın habis neoplazması',
KURUM: 'Devlet' ,
DONEM: 'OCAK 2014',
SAYI: 2,
INSIDANS:2
},{
HASTANE: 'TKD',
SEHIR: 'Tekirdağ',
BOLGE: 'Marmara Bölgesi ',
KOD: 'C00',
KODACIKLAMA: 'Dudağın habis neoplazması',
KURUM: 'Devlet' ,
DONEM: 'OCAK 2014',
SAYI: 1,
INSIDANS:1
},{
HASTANE: 'ADN',
SEHIR: 'Adana',
BOLGE: 'Akdeniz Bölgesi',
KOD: 'C00',
KODACIKLAMA: 'Dudağın habis neoplazması',
KURUM: 'Devlet' ,
DONEM: 'OCAK 2014',
SAYI: 1,
INSIDANS:1
},{
HASTANE: 'ESKYM',
SEHIR: 'Eskişehir',
BOLGE: 'İç Anadolu Bölgesi ',
KOD: 'C00',
KODACIKLAMA: 'Dudağın habis neoplazması',
KURUM: 'Devlet' ,
DONEM: 'OCAK 2014',
SAYI: 1,
INSIDANS:1
},{
HASTANE: 'IST',
SEHIR: 'İstanbul',
BOLGE: 'Marmara Bölgesi ',
KOD: 'C00',
KODACIKLAMA: 'Dudağın habis neoplazması',
KURUM: 'Devlet' ,
DONEM: 'OCAK 2014',
SAYI: 2,
INSIDANS:2
}]
var mapChart = dc.bubbleOverlay("#map").svg(d3.select("#map svg"));
var donemRowMapChart = dc.rowChart("#donem-map-chart");
var bolgeRowMapChart = dc.rowChart("#bolge-map-chart");
var d= [data];
var data = crossfilter(d);
var sehir=data.dimension(function(d){return d.SEHIR;});
var donem=data.dimension(function(d){return d.DONEMADI;});
var bolge=data.dimension(function(d){return d.BOLGE;});
var sehirGroup=sehir.group().reduceSum(function(d){return d.INSIDANS});
var donemGroup=donem.group().reduceSum(function(d){return d.INSIDANS});
var bolgeGroup=bolge.group().reduceSum(function(d){return d.INSIDANS});
mapChart.width(600)
.height(450)
.dimension(sehir)
.group(sehirGroup)
.radiusValueAccessor(function(p) {
return p.value;
})
.r(d3.scale.linear().domain([0, 200000]))
.colors(["#ff7373","#ff4040","#ff0000","#bf3030","#a60000"])
.colorDomain([13, 30])
.colorAccessor(function(p) {
return p.value;
})
.title(function(d) {
return "City: " + d.key
+ "\nINSIDANS SAYISI: " +d.value;
})
.point("TR.GA", 364, 400)
.point("TR.ED", 395.5, 383)
.debug(false);
donemRowMapChart
.width(300)
.height(200)
.margins({top: 5, left: 10, right: 10, bottom: 20})
.dimension(donem)
.group(donemGroup)
.colors(d3.scale.category10())
.elasticX(true)
.xAxis().ticks(4);
bolgeRowMapChart
.width(300)
.height(200)
.margins({top: 5, left: 10, right: 10, bottom: 20})
.dimension(bolge)
.group(bolgeGroup)
.colors(d3.scale.category10())
.elasticX(true)
.xAxis().ticks(4);
dc.renderAll();
第178行第4行引发错误,第4行:crossfilter.js:
function quicksort(a, lo, hi) {
// Compute the two pivots by looking at 5 elements.
var sixth = (hi - lo) / 6 | 0,
i1 = lo + sixth,
i5 = hi - 1 - sixth,
i3 = lo + hi - 1 >> 1, // The midpoint.
i2 = i3 - sixth,
i4 = i3 + sixth;
........................}
那么如何修复thiis错误。
感谢帮助
答案 0 :(得分:2)
当我的尺寸不是自然排序时,通常会发生这种情况。您通常希望投射用于制作维度的任何值。具体而言,DONEMADI可能不是您的许多数据对象的属性,因为它不会出现在您的示例数据中。我将您的代码更改为
var sehir=data.dimension(function(d){return "" + d.SEHIR;});
var donem=data.dimension(function(d){return "" + d.DONEMADI;});
var bolge=data.dimension(function(d){return "" + d.BOLGE;});
var sehirGroup=sehir.group().reduceSum(function(d){return +d.INSIDANS});
var donemGroup=donem.group().reduceSum(function(d){return +d.INSIDANS});
var bolgeGroup=bolge.group().reduceSum(function(d){return +d.INSIDANS});
如果你这样做,你还能看到问题吗?