Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/446.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript highcharts将不会呈现给我的div_Javascript_Backbone.js_Highcharts - Fatal编程技术网

Javascript highcharts将不会呈现给我的div

Javascript highcharts将不会呈现给我的div,javascript,backbone.js,highcharts,Javascript,Backbone.js,Highcharts,我正在尝试将highchart演示呈现给backbone.js小部件 我正在尝试在我的小部件中包含,模板生成,除了HighCharts之外的所有东西都在工作。我怀疑highchart在渲染到尚未放在DOM上的div时遇到问题,因为我可以在之后添加图表 对于如何在渲染周期中将图表小部件添加到树中,anyont有什么想法吗 window.HomeView = Backbone.View.extend({ initialize:function () {}, render:func

我正在尝试将highchart演示呈现给backbone.js小部件

我正在尝试在我的小部件中包含,模板生成,除了HighCharts之外的所有东西都在工作。我怀疑highchart在渲染到尚未放在DOM上的div时遇到问题,因为我可以在之后添加图表

对于如何在渲染周期中将图表小部件添加到树中,anyont有什么想法吗

window.HomeView = Backbone.View.extend({

    initialize:function () {},

    render:function () {
        $(this.el).html(this.template());
        var chart = $("#chart", this.el)[0];
        this.renderChart(chart);        
        return this;
    },

    renderChart: function(container) {

        var colors = Highcharts.getOptions().colors,
            categories = ['MSIE', 'Firefox', 'Chrome', 'Safari', 'Opera'],
            name = 'Browser brands',
            data = [{
                    y: 55.11,
                    color: colors[0],
                    drilldown: {
                        name: 'MSIE versions',
                        categories: ['MSIE 6.0', 'MSIE 7.0', 'MSIE 8.0', 'MSIE 9.0'],
                        data: [10.85, 7.35, 33.06, 2.81],
                        color: colors[0]
                    }
                }, {
                    y: 21.63,
                    color: colors[1],
                    drilldown: {
                        name: 'Firefox versions',
                        categories: ['Firefox 2.0', 'Firefox 3.0', 'Firefox 3.5', 'Firefox 3.6', 'Firefox 4.0'],
                        data: [0.20, 0.83, 1.58, 13.12, 5.43],
                        color: colors[1]
                    }
                }, {
                    y: 11.94,
                    color: colors[2],
                    drilldown: {
                        name: 'Chrome versions',
                        categories: ['Chrome 5.0', 'Chrome 6.0', 'Chrome 7.0', 'Chrome 8.0', 'Chrome 9.0',
                            'Chrome 10.0', 'Chrome 11.0', 'Chrome 12.0'],
                        data: [0.12, 0.19, 0.12, 0.36, 0.32, 9.91, 0.50, 0.22],
                        color: colors[2]
                    }
                }, {
                    y: 7.15,
                    color: colors[3],
                    drilldown: {
                        name: 'Safari versions',
                        categories: ['Safari 5.0', 'Safari 4.0', 'Safari Win 5.0', 'Safari 4.1', 'Safari/Maxthon',
                            'Safari 3.1', 'Safari 4.1'],
                        data: [4.55, 1.42, 0.23, 0.21, 0.20, 0.19, 0.14],
                        color: colors[3]
                    }
                }, {
                    y: 2.14,
                    color: colors[4],
                    drilldown: {
                        name: 'Opera versions',
                        categories: ['Opera 9.x', 'Opera 10.x', 'Opera 11.x'],
                        data: [ 0.12, 0.37, 1.65],
                        color: colors[4]
                    }
                }];


        // Build the data arrays
        var browserData = [];
        var versionsData = [];
        for (var i = 0; i < data.length; i++) {

            // add browser data
            browserData.push({
                name: categories[i],
                y: data[i].y,
                color: data[i].color
            });

            // add version data
            for (var j = 0; j < data[i].drilldown.data.length; j++) {
                var brightness = 0.2 - (j / data[i].drilldown.data.length) / 5 ;
                versionsData.push({
                    name: data[i].drilldown.categories[j],
                    y: data[i].drilldown.data[j],
                    color: Highcharts.Color(data[i].color).brighten(brightness).get()
                });
            }
        }


        // Create the chart
        var chart = new Highcharts.Chart({
            chart: {
                renderTo: container,
                type: 'pie'
            },
            title: {
                text: 'Browser market share, April, 2011'
            },
            yAxis: {
                title: {
                    text: 'Total percent market share'
                }
            },
            plotOptions: {
                pie: {
                    shadow: false
                }
            },
            tooltip: {
                valueSuffix: '%'
            },
            series: [{
                name: 'Browsers',
                data: browserData,
                size: '60%',
                dataLabels: {
                    formatter: function() {
                        return this.y > 5 ? this.point.name : null;
                    },
                    color: 'white',
                    distance: -30
                }
            }, {
                name: 'Versions',
                data: versionsData,
                innerSize: '60%',
                dataLabels: {
                    formatter: function() {
                        // display only if larger than 1
                        return this.y > 1 ? '<b>'+ this.point.name +':</b> '+ this.y +'%'  : null;
                    }
                }
            }]
        });
    }
});
window.HomeView=Backbone.View.extend({
初始化:函数(){},
渲染:函数(){
$(this.el).html(this.template());
var图表=$(“#图表”,this.el)[0];
本图为renderChart(图表);
归还这个;
},
renderChart:函数(容器){
var colors=Highcharts.getOptions().colors,
类别=['MSIE'、'Firefox'、'Chrome'、'Safari'、'Opera'],
名称='浏览器品牌',
数据=[{
y:55.11,
颜色:颜色[0],
向下展开:{
名称:“MSIE版本”,
类别:['MSIE 6.0','MSIE 7.0','MSIE 8.0','MSIE 9.0'],
数据:[10.85,7.35,33.06,2.81],
颜色:颜色[0]
}
}, {
y:21.63,
颜色:颜色[1],
向下展开:{
名称:“Firefox版本”,
类别:[“Firefox 2.0”、“Firefox 3.0”、“Firefox 3.5”、“Firefox 3.6”、“Firefox 4.0”],
数据:[0.20,0.83,1.58,13.12,5.43],
颜色:颜色[1]
}
}, {
y:11.94,
颜色:颜色[2],
向下展开:{
名称:“Chrome版本”,
类别:[“Chrome 5.0”、“Chrome 6.0”、“Chrome 7.0”、“Chrome 8.0”、“Chrome 9.0”,
“Chrome 10.0”、“Chrome 11.0”、“Chrome 12.0”],
数据:[0.12,0.19,0.12,0.36,0.32,9.91,0.50,0.22],
颜色:颜色[2]
}
}, {
y:7.15,
颜色:颜色[3],
向下展开:{
名称:“Safari版本”,
类别:[“Safari 5.0”、“Safari 4.0”、“Safari Win 5.0”、“Safari 4.1”、“Safari/Maxthon”,
“Safari 3.1”、“Safari 4.1”],
数据:[4.55,1.42,0.23,0.21,0.20,0.19,0.14],
颜色:颜色[3]
}
}, {
y:2.14,
颜色:颜色[4],
向下展开:{
名称:“歌剧版”,
类别:['Opera9.x','Opera10.x','Opera11.x'],
数据:[0.12,0.37,1.65],
颜色:颜色[4]
}
}];
//构建数据阵列
var browserData=[];
var versionsData=[];
对于(变量i=0;i5?this.point.name:空;
},
颜色:'白色',
距离:-30
}
}, {
名称:'版本',
数据:versionsData,
内部尺寸:“60%”,
数据标签:{
格式化程序:函数(){
//仅当大于1时显示
返回this.y>1?''+this.point.name+':'+this.y+'%':null;
}
}
}]
});
}
});
到目前为止,我的最佳解决方案是触发一个事件,并进行后期渲染循环

这绝对不是最佳选择。

请尝试以下方法:

render: function () {
    var element = this.el;
    $(this.el).html(this.template());
    $("#chart").append(element);
    this.renderChart(element);        
    return this;
}

问题是$(this.el)可能还不在DOM上。。它可能在某个页面上作为小部件生成,并在以后添加到DOM中。。因此,呈现图表将不起作用。我得到了一个DOM插入错误,这是有意义的,因为我正在尝试将元素插入自身。请记住,中的#图表是在此.template()生成的代码中定义的。这意味着查找$('#chart')没有意义,因为#chart在$(this.el)中。再说一次,#图表可能还没有添加到DOM中,因为它可能是更大的小部件的一部分