angularJs在多个控制器中共享服务数据的方法
更新时间:2018年09月30日 10:50:03 作者:泠泠在路上
今天小编就为大家分享一篇angularJs在多个控制器中共享服务数据的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
如下所示:
<div ng-app="module">
<div ng-controller="ctrl1">
<table border="1" width="600">
<tr>
<td>网站名称</td>
<td>网址</td>
</tr>
<tr ng-repeat="v in data.webs">
<td>{{v.name}}</td>
<td>{{v.url}}</td>
</tr>
</table>
</div>
<hr>
<div ng-controller="ctrl2">
<table border="1" width="600">
<tr>
<td>网站名称</td>
<td>网址</td>
</tr>
<tr ng-repeat="v in data.webs">
<td>{{v.name}}</td>
<td>{{v.url}}</td>
</tr>
</table>
<h1>{{web.name}}</h1>
<button ng-click="removeAll()">删除所有数据</button>
</div>
</div>
<script>
var m = angular.module('module', []);
//定义服务
m.factory('videoServer', ['$http', function ($http) {
var obj = {
data: {webs:[]},
//所有数据
all: function () {
return $http({url: '1.php'}).then(function (response) {
obj.data.webs = response.data;
return obj.data;
});
},
//获取一条数据
find: function (id) {
return this.all().then(function (data) {
for (var i = 0; i < data.length; i++) {
if (data[i].id == id) {
return data[i];
}
}
});
},
//删除所有数据
flush: function () {
obj.data.webs=[];
}
};
return obj;
}]);
//控制器ctrl1
m.controller('ctrl1', ['$scope', 'videoServer', function ($scope, videoServer) {
videoServer.all().then(function (data) {
$scope.data = data;
});
}]);
//控制器ctrl2
m.controller('ctrl2', ['$scope', 'videoServer', function ($scope, videoServer) {
videoServer.all().then(function (data) {
$scope.data = data;
});
videoServer.find(1).then(function (data) {
$scope.web = data;
})
$scope.removeAll=function(){
videoServer.flush();
}
}]);
</script>
1.php
<?php $data = [ [ 'name' => '百度', 'url' => 'www.baidu.com' ], [ 'name' => '谷歌', 'url' => 'google.com' ], ]; echo json_encode($data,JSON_UNESCAPED_UNICODE);
以上这篇angularJs在多个控制器中共享服务数据的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
详解angularjs获取元素以及angular.element()用法
本篇文章主要介绍了详解angularjs获取元素以及angular.element()用法 ,具有一定的参考价值,有兴趣的可以了解一下2017-07-07
Angular中使用ng-zorro图标库部分图标不能正常显示问题
这篇文章主要介绍了Angular中使用ng-zorro图标库部分图标不能正常显示问题,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2019-04-04
AngularJS 与Bootstrap实现表格分页实例代码
这篇文章主要介绍了AngularJS 与Bootstrap实现表格分页的相关资料,并附实例代码和实现效果图,需要的朋友可以参考下2016-10-10


最新评论