2016-02-15 121 views
1

我遵循此url。在這裏我正在寫數據變量並將數據分配給指令本身。如何使用angularjs從外部文件獲取json數據

但是我已經在不同的sample.json file.Then JSON數據如何將sample.json數據進入角directive.Can請人幫我了關於這個問題......

我的js :

angular.module('myApp').directive('multiLine', [ 
    function() { 
    return { 
     restrict: 'E', 
     scope: { 
     data: '=' 
     }, 
     link: function(scope, element) { 


var data = [ 
    { 
     "City": "New York", 
     "Data": [ 
      { 
       "Date": "20111001", 
       "Value": "63.4" 
      }, 
      { 
       "Date": "20111002", 
       "Value": "58.0" 
      }, 
      { 
       "Date": "20111003", 
       "Value": "53.3" 
      } 
     ] 
    }, 
    { 
     "City": "San Francisco", 
     "Data": [ 
      { 
       "Date": "20111001", 
       "Value": "62.7" 
      }, 
      { 
       "Date": "20111002", 
       "Value": "59.9" 
      }, 
      { 
       "Date": "20111003", 
       "Value": "59.1" 
      } 
     ] 
    }, 
    { 
     "City": "Austin", 
     "Data": [ 
      { 
       "Date": "20111001", 
       "Value": "72.2" 
      }, 
      { 
       "Date": "20111002", 
       "Value": "67.7" 
      }, 
      { 
       "Date": "20111003", 
       "Value": "69.4" 
      } 
     ] 
    } 
]; 

var margin = { 
    top: 20, 
    right: 80, 
    bottom: 30, 
    left: 50 
}, 
width = 560 - margin.left - margin.right, 
    height = 300 - margin.top - margin.bottom; 

var parseDate = d3.time.format("%Y%m%d").parse; 

var x = d3.time.scale() 
    .range([0, width]); 

var y = d3.scale.linear() 
    .range([height, 0]); 

var color = d3.scale.category10(); 

var xAxis = d3.svg.axis() 
    .scale(x) 
    .orient("bottom"); 

var yAxis = d3.svg.axis() 
    .scale(y) 
    .orient("left"); 

var line = d3.svg.line() 
    .interpolate("basis") 
    .x(function (d) { 
    return x(d.Date); 
}) 
    .y(function (d) { 
    return y(d.Value); 
}); 

var svg = d3.select(element[0]).append("svg") 
    .attr("width", width + margin.left + margin.right) 
    .attr("height", height + margin.top + margin.bottom) 
    .append("g") 
    .attr("transform", "translate(" + margin.left + "," + margin.top + ")"); 

color.domain(data.map(function (d) { return d.City; })); 

data.forEach(function (kv) { 
    kv.Data.forEach(function (d) { 
     d.Date = parseDate(d.Date); 
    }); 
}); 

var cities = data; 

var minX = d3.min(data, function (kv) { return d3.min(kv.Data, function (d) { return d.Date; }) }); 
var maxX = d3.max(data, function (kv) { return d3.max(kv.Data, function (d) { return d.Date; }) }); 
var minY = d3.min(data, function (kv) { return d3.min(kv.Data, function (d) { return d.Value; }) }); 
var maxY = d3.max(data, function (kv) { return d3.max(kv.Data, function (d) { return d.Value; }) }); 

x.domain([minX, maxX]); 
y.domain([minY, maxY]); 

svg.append("g") 
    .attr("class", "x axis") 
    .attr("transform", "translate(0," + height + ")") 
    .call(xAxis); 

svg.append("g") 
    .attr("class", "y axis") 
    .call(yAxis) 
    .append("text") 
    .attr("transform", "rotate(-90)") 
    .attr("y", 6) 
    .attr("dy", ".71em") 
    .style("text-anchor", "end") 
    .text("Temperature (ºF)"); 

var city = svg.selectAll(".city") 
    .data(cities) 
    .enter().append("g") 
    .attr("class", "city"); 

city.append("path") 
    .attr("class", "line") 
    .attr("d", function (d) { 
    return line(d.Data); 
}) 
    .style("stroke", function (d) { 
    return color(d.City); 
}); 

city.append("text") 
    .datum(function (d) { 
    return { 
     name: d.City, 
     date: d.Data[d.Data.length - 1].Date, 
     value: d.Data[d.Data.length - 1].Value 
    }; 
}) 
    .attr("transform", function (d) { 
    return "translate(" + x(d.date) + "," + y(d.value) + ")"; 
}) 
    .attr("x", 3) 
    .attr("dy", ".35em") 
    .text(function (d) { 
     return d.name; 
}); 
} 
    }; 
    } 
]); 

回答

0

您可以使用$http。例如:

$http({method: 'GET', url:'path/to/file.json'}) 
    .then(
     function(json) { 
      console.log('result: ', json); 
     }, 
     function(error) { 
      Console.warn('An error occured'); 
     } 
    ); 

您也可以使用$http.get作爲便利功能。

0

進樣$http到你的指令:

angular.module('myApp').directive('multiLine', ['$http', function($http) { 

使用它的get方法來獲取文件:

$http.get('file.json').then(
    function resolved (response) { 
     console.info('Resolved at ' + new Date()); 
     // response.data holds your JSON object 
    }, 
    function rejected (response) { 
     console.error('Rejected at ' + new Date()); 
    } 
); 

參考:https://docs.angularjs.org/api/ng/service/$http#get

+0

u能請編輯模塊名來對myApp – dev777

+0

OK,是會做 – iH8

0

如果你想從其他的JSON對象文件你可以使用http獲取方法如下:

app.controller("testController", function($scope, $http) { 
    $scope.data= []; 
     $http.get('data.json').success(function(data) { 
     $scope.data = data.value; 
     console.log(data.value); 
     });  
}); 

檢查此鏈接:https://docs.angularjs.org/api/ng/service/ $ HTTP

+0

的$ HTTP遺留承諾的方法成功錯誤已被棄用。改爲使用標準然後方法。如果$ httpProvider.useLegacyPromiseExtensions設置爲false,那麼這些方法將拋出$ http/legacy錯誤。請參閱:[https://docs.angularjs.org/api/ng/service/$http#deprecation-notice](https://docs.angularjs.org/api/ng/service/$http#deprecation-notice) – iH8

+0

噢好吧。我不知道$ http遺留承諾方法的成功和錯誤已被棄用,因爲我們仍然使用它。感謝那些有用的信息。 – Gracia

0
Here I created sample for how to get data from external json. 

Sample Link

myApp.factory('Data', ['$http', function($http) { 
    var dataFactory = {}; 
    dataFactory.getdata = function() { 
       return $http.get('your.json'); 
     }; 
    return dataFactory; 
}]); 

myApp.controller('FirstCtrl', function($scope, Data){ 
    Data.getdata().then(function (data) { 
     $scope.Data = data.data; 
    }); 
}); 
相關問題