将数据作为js变量传递给highchart

时间:2015-08-08 10:56:45

标签: javascript php

我有一个关联php数组(field_data),我想用json_encode函数将它传递给JS:$jArray = json_encode($field_data); 我在JS中收到了数组:var irbrowser = <?php echo $jArray; ?>;但是在js中,当我想将jArray中的值设置为饼图数据时,它不会呈现任何内容。

 <?php
        $jArray = json_encode($field_data);
?>

<div dir="ltr" id="container"> </div>

<script>
    var irbrowser = <?php echo $jArray; ?>;

    $(function () {
    $('#container').highcharts({
        chart: {
            plotBackgroundColor: null,
            plotBorderWidth: null,
            plotShadow: false,
            type: 'pie'
        },
        title: {
            text: 'Browser market shares'
        },
        tooltip: {
            pointFormat: '{series.name}: <b>{point.percentage:.1f}%</b>'
        },
        plotOptions: {
            pie: {
                allowPointSelect: true,
                cursor: 'pointer',
                dataLabels: {
                    enabled: true,
                    format: '<b>{point.name}</b>: {point.percentage:.1f} %',
                    style: {
                        color: (Highcharts.theme && Highcharts.theme.contrastTextColor) || 'black'
                    }
                }
            }
        },
        series: [{
            name: "Brands",
            colorByPoint: true,
            data: [{
                name: "IE",
                y: irbrowser.IE
            }, {
                name: "Chrome",
                y: irbrowser.Chrome,
                sliced: true,
                selected: true
            }, {
                name: "Proprietary or Undetectable",
                y: irbrowser.Other
            }]
        }]
    });
});

 </script>

2 个答案:

答案 0 :(得分:1)

我发现了问题。 它应该转换为Float。所以我使用parseFloate(irbrowser)函数。并将变量设置为y。那段代码

series: [{
        name: "Brands",
        colorByPoint: true,
        data: [{
            name: "IE",
            y: parseFloat(irbrowser.IE)
        }, {
            name: "Chrome",
            y: parseFloat(irbrowser.Chrome),
            sliced: true,
            selected: true
        }, {
            name: "Proprietary or Undetectable",
            y: 0.5
        }]
    }]

答案 1 :(得分:0)

查看脚本的前几行

  

第1行你停止PHP解释器

     

第2行你尝试了一行PHP ??

     

第3行启动PHP解释器

     

第4行,您尝试在PHP部分内输出原始HTML

 ?>
        $jArray = json_encode($field_data);
<?php

<div dir="ltr" id="container"> </div>

<script>
    var irbrowser = <?php echo $jArray; ?>;

尝试

        $jArray = json_encode($field_data);
?>

<div dir="ltr" id="container"> </div>

<script>
    var irbrowser = <?php echo $jArray; ?>;