简体   繁体   English

Gettin crossfilter.js错误“太多的递归”

[英]Gettin crossfilter.js error “too much recursion”

Iam getting error "too much recursion" on crossfilter.js How can I fix this error. 我在crossfilter.js上收到错误"too much recursion"如何解决此错误。

Here my javascript codes(I am giving data from php.So data is not wrong.I think dimension error): 这是我的JavaScript代码(我从php提供数据,因此数据没有错。我认为尺寸错误):

 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(); 

Error raising on line 178,col 4 crossfilter.js : 在第178行第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;

........................}

So How can I fix thiis error. 那么我该如何解决这个错误。

Thanks For Helps 感谢您的帮助

Usually this happens to me when I have dimensions that are not naturally ordered. 通常,当我具有不自然排序的尺寸时,这会发生在我身上。 You'll usually want to cast any value that you use to make a dimension. 通常,您需要转换用于创建尺寸的任何值。 Specifically, DONEMADI may not be a property on many of your data objects as it doesn't appear in your sample data. 特别是,DONEMADI可能不是许多数据对象的属性,因为它没有出现在样本数据中。 I'd change your code to 我将您的代码更改为

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});

Do you still see the problem if you do this? 如果这样做,您仍然看到问题吗?

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM