Che*_*niv 8 javascript xml client-server client-side angularjs
我正在寻找一种在加载应用程序后从DOM获取初始数据的方法.数据已由服务器插入视图中.是Module
的value
方法是一个很好的办法吗?
我也想知道如何在routes
我使用时从视图中获取数据,我可以使用script
标签在特定范围内注入数据吗?
Che*_*niv 16
1)受这个问题启发的第一个解决方案,它Module
的value
方法是:
<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>
Run Code Online (Sandbox Code Playgroud)
然后我们可以PrimaryData
在我们希望的时间和地点使用它,如下所示:
myApp.controller('MainCtrl', function($scope, PrimaryData) {
$scope.data = angular.copy(PrimaryData);
console.log( $scope.data[0].name === "John" );
});
Run Code Online (Sandbox Code Playgroud)
但是当我开始使用时routes
,这种方式对我来说不起作用,可能是因为value
应用程序初始化时只运行.
2)所以这是第二个解决方案:指令.现在,当服务器发送路由的模板时,它会在某个script
标签中放入一个"text/template"
类型和特殊指令名称属性以及该标记中的json数据,如下所示:
<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>
Run Code Online (Sandbox Code Playgroud)
并且该指令捕获它并将数据传递到当前路由的范围:
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" );
}
}
}
});
Run Code Online (Sandbox Code Playgroud)
真棒!:)