1) Pierwsze rozwiązanie inspirowane this question i jest Module
's value
method:
<script>
var users_json = '[{"name":"Piotr"},{"name":"Natasha"}]'; // created by xsl
myApp.value("PrimaryData" , users_json);
</script>
<ul>
<li ng-repeat="user in users">{{user.name}}</li>
</ul>
Wtedy możemy użyć tego PrimaryData
kiedy i gdzie chcemy, tak:
myApp.controller('MainCtrl', function($scope, PrimaryData) {
$scope.data = angular.copy(PrimaryData);
console.log($scope.data[0].name === "John");
});
Ale w ten sposób jakoś nie pracował dla mnie, gdy zacząłem używać routes
, może być, ponieważ value
działa tylko podczas inicjowania aplikacji.
2) Oto drugie rozwiązanie: dyrektywy. Teraz, gdy serwer wysyła szablon trasy za, stawia wewnątrz jakiegoś script
tagu z "text/template"
rodzaju i szczególnej właściwości name dyrektywą oraz danych JSON w tym tagu, tak:
<script type = "text/template" rawdata > <!-- "rawdata" is our directive
'[{"name":"Nelson"},{"name":"Luis"}]' // created by xsl
</script>
<ul>
<li ng-repeat="user in users">{{user.name}}</li> // view is beside
</ul>
a niniejszą dyrektywą łapie go i przekazuje dane do bieżącej trasy "zakres:
studio.directive('rawdata', function() {
return {
link: function(scope, element, attr, ctrl) {
if(scope.passRawData){
var data = (element[0].innerHTML);
scope.passRawData(data); // Or simply scope.users = JSON.parse(data)
} else {
console.log("Scope has no passRawData method");
}
}
}
});
Awesome! :)
możliwy duplikat [wstępne ładowanie danych w angularjs] (http://stackoverflow.com/questions/18086823/initial-data-loading-in-angularjs) –