未捕获的ReferenceError:未定义Tankvalue

时间:2017-06-28 07:11:12

标签: javascript html angularjs fusioncharts

我想在图表中显示响应数据。但是Tankvalue超出范围并提供错误消息

  

Tankvalue未定义。

如何使变量可以全局访问。由于未定义的值,图表未加载。想在图表中显示Tankvalue

var app = angular.module('myApp', []);
app.controller('myCtrl', function ($scope, $http) {
    $http.get('url', {
            headers: {
                'Authorization': 'Basic Pasword=='
            }
        })
        .then(function (response) {
            $scope.names = response.data;
            $scope.decodedFrame = atob($scope.names.dataFrame);
            var Tankvalue = $scope.decodedFrame.substring(6);


        });
});
FusionCharts.ready(function () {
    var fusioncharts = new FusionCharts({
        type: 'cylinder',
        dataFormat: 'json',
        id: 'fuelMeter-1',
        renderAt: 'chart-container',
        width: '200',
        height: '350',
        dataSource: {
            "chart": {
                "theme": "fint",
                "caption": "Tank",
                "subcaption": "Bakersfield Central",
                "lowerLimit": "0",
                "upperLimit": "25",
                "lowerLimitDisplay": "Empty",
                "upperLimitDisplay": "Full",
                "numberSuffix": " ltrs",
                "showValue": "1",
                "chartBottomMargin": "45",
                "showValue": "0"
            },
            "value": Tankvalue,
            "annotations": {
                "origw": "400",
                "origh": "190",
                "autoscale": "1",
                "groups": [{
                    "id": "range",
                    "items": [{
                        "id": "rangeBg",
                        "type": "rectangle",
                        "x": "$canvasCenterX-45",
                        "y": "$chartEndY-30",
                        "tox": "$canvasCenterX +45",
                        "toy": "$chartEndY-75",
                        "fillcolor": "#6caa03"
                    }, {
                        "id": "rangeText",
                        "type": "Text",
                        "fontSize": "11",
                        "fillcolor": "#333333",
                        "text": "80 ltrs",
                        "x": "$chartCenterX-45",
                        "y": "$chartEndY-50"
                    }]
                }]
            }

        },

    });
    fusioncharts.render();
});

3 个答案:

答案 0 :(得分:1)

Move FusionCharts.ready() inside then block as shown below.
.then(function (response) {
            $scope.names = response.data;
            $scope.decodedFrame = atob($scope.names.dataFrame);
            var Tankvalue = $scope.decodedFrame.substring(6);

            FusionCharts.ready(function () {
                var fusioncharts = new FusionCharts({
                    type: 'cylinder',
                    dataFormat: 'json',
                    id: 'fuelMeter-1',
                    renderAt: 'chart-container',
                    width: '200',
                    height: '350',
                    dataSource: {
                        "chart": {
                            "theme": "fint",
                            "caption": "Tank",
                            "subcaption": "Bakersfield Central",
                            "lowerLimit": "0",
                            "upperLimit": "25",
                            "lowerLimitDisplay": "Empty",
                            "upperLimitDisplay": "Full",
                            "numberSuffix": " ltrs",
                            "showValue": "1",
                            "chartBottomMargin": "45",
                            "showValue": "0"
                        },
                        "value": Tankvalue,
                        "annotations": {
                            "origw": "400",
                            "origh": "190",
                            "autoscale": "1",
                            "groups": [{
                                "id": "range",
                                "items": [{
                                    "id": "rangeBg",
                                    "type": "rectangle",
                                    "x": "$canvasCenterX-45",
                                    "y": "$chartEndY-30",
                                    "tox": "$canvasCenterX +45",
                                    "toy": "$chartEndY-75",
                                    "fillcolor": "#6caa03"
                                }, {
                                    "id": "rangeText",
                                    "type": "Text",
                                    "fontSize": "11",
                                    "fillcolor": "#333333",
                                    "text": "80 ltrs",
                                    "x": "$chartCenterX-45",
                                    "y": "$chartEndY-50"
                                }]
                            }]
                        }

                    },

                });
                fusioncharts.render();
            });

        });

答案 1 :(得分:0)

您不能将局部变量用于其他函数。使用$ scope将其作为全局或make作为范围变量。

$scope.Tankvalue = $scope.decodedFrame.substring(6);

答案 2 :(得分:0)

$http.get()是异步函数,因此FusionCharts.ready()在分配给Tankvalue变量的值之前运行。 要在ready()内修复此移动.then()

这样做:

var app = angular.module('myApp', []);
app.controller('myCtrl', function ($scope, $http) {
    $http.get('url', {
            headers: {
                'Authorization': 'Basic Pasword=='
            }
        })
      .then(function (response) {
        $scope.names = response.data;
        $scope.decodedFrame = atob($scope.names.dataFrame);
        var Tankvalue = $scope.decodedFrame.substring(6);
        FusionCharts.ready(function () {
        var fusioncharts = new FusionCharts({
        type: 'cylinder',
        dataFormat: 'json',
        id: 'fuelMeter-1',
        renderAt: 'chart-container',
        width: '200',
        height: '350',
        dataSource: {
            "chart": {
                "theme": "fint",
                "caption": "Tank",
                "subcaption": "Bakersfield Central",
                "lowerLimit": "0",
                "upperLimit": "25",
                "lowerLimitDisplay": "Empty",
                "upperLimitDisplay": "Full",
                "numberSuffix": " ltrs",
                "showValue": "1",
                "chartBottomMargin": "45",
                "showValue": "0"
            },
            "value": Tankvalue,
            "annotations": {
                "origw": "400",
                "origh": "190",
                "autoscale": "1",
                "groups": [{
                    "id": "range",
                    "items": [{
                        "id": "rangeBg",
                        "type": "rectangle",
                        "x": "$canvasCenterX-45",
                        "y": "$chartEndY-30",
                        "tox": "$canvasCenterX +45",
                        "toy": "$chartEndY-75",
                        "fillcolor": "#6caa03"
                    }, {
                        "id": "rangeText",
                        "type": "Text",
                        "fontSize": "11",
                        "fillcolor": "#333333",
                        "text": "80 ltrs",
                        "x": "$chartCenterX-45",
                        "y": "$chartEndY-50"
                    }]
                }]
            }

        },

    });
    fusioncharts.render();
   });   
  });
});