AngularJS数据源的多种获取方式汇总


Posted in Javascript onFebruary 02, 2016

AngularJS 简介

AngularJS 是由 Google 发起的一款开源的前端 MVC 脚本框架,既适合做普通 WEB 应用也可以做 SPA(单页面应用,所有的用户操作都在一个页面中完成)。与同为 MVC 框架的 Dojo 的定位不同,AngularJS 在功能上更加轻量,而相比于 jQuery,AngularJS 又帮您省去了许多机械的绑定工作。在一些对开发速度要求高,功能模块不需要太丰富的非企业级 WEB 应用上,AngularJS 是一个非常好的选择。AngularJS 最为复杂同时也是最强大的部分就是它的数据绑定机制,这个机制帮助我们能更好的将注意力集中在数据的模型建立和传递上,而不是对底层的 DOM 进行低级的操作。

在AngularJS中,可以从$rootScope中获取数据源,也可以把获取数据的逻辑封装在service中,然后注入到app.run函数中,或者注入到controller中。本篇就来整理获取数据的几种方式。

■ 数据源放在$rootScope中

var app = angular.module("app",[]);
app.run(function($rootScope){
$rootScope.todos = [
{item:"",done:true},
{item:"",done:false}
];
})
<div ng-repeat="todo in todos">
{{todo.item}}
</div>
<form>
<input type="text" ng-model="newTodo" />
<input type="submit" ng-click=""todos.push({item:newTodo, done:false}) />
</form>

以上,把数据源放在$rootScope中的某个字段中,很容易被重写。

■ 数据源放在service中,把servie注入到run函数中

app.service("TodoService", function(){
this.todos = [
{item:"",done:true},
{item:"",done:false}
];
})
app.run(function($rootScope, TodoService){
$rootScope.TodoService = TodoService;
}) 
<div ng-repeat="todo in TodoService.todos">
{{todo.item}}
</div>
<form>
<input type="text" ng-model="newTodo" />
<input type="submit" ng-click=""TodoService.todos.push({item:newTodo, done:false}) />
</form>

在html中似乎这样写比较好:

<input type="submit" ng-click=""TodoService.todos.addodo(newTodo) />

在service中增加一个方法:

app.service("TodoService", function(){
this.todos = [
{item:"",done:true},
{item:"",done:false}
];
this.addTodo = fucntion(newTodo){
this.todos.push({item:newTodo, done:false})
}
})

■ 数据源放在service中,把servie注入到controller中

app.controller("TodoCtrl", function($scope, TodoService){
this.TodoService = TodoServce;
})

在对应的html中:

<body ng-app="app" ng-controller="TodoCtrl as todoCtrl">
<div ng-repeat="todo in todoCtrl.TodoService.todos">
{{todo.item}}
</div>
</body>
<form>
<input type="text" ng-model="newTodo" />
<input type="submit" ng-click="todoCtrl.TodoService.addTodo(newTodo)"/>
</form>

■ 数据源放在service中,把servie注入到controller中,与服务端交互

在实际项目中,service还需要和服务端交互。

var app = angular.module("app",[]);
app.service("TodoService", function($q, $timeout){
this.getTodos = function(){
var d = $q.defer();
//模拟一个请求
$timeout(function(){
d.resolve([
{item:"", done:false},
...
])
},3000);
return d.promise;
}
this.addTodo = function(item){
this.todos.push({item:item, done:false});
}
})
app.controller("TodoCtrl", function(TodoService){
var todoCtrl = this;
TodoService.getTodos().then(function(result){
todoCtrl.todos = result;
})
todoCtrl.addTodo = TodoService.addTodo;
})

以上所述是小编给大家分享的AngularJS数据源的多种获取方式汇总,希望对大家有所帮助。

Javascript 相关文章推荐
Ajax一统天下之Dojo整合篇
Mar 24 Javascript
Javascript类定义语法,私有成员、受保护成员、静态成员等介绍
Dec 08 Javascript
28个常用JavaScript方法集锦
Jan 14 Javascript
Node.js服务器环境下使用Mock.js拦截AJAX请求的教程
May 23 Javascript
如何检测JavaScript的各种类型
Jul 30 Javascript
AngularJS实现表格的增删改查(仅限前端)
Jul 04 Javascript
关于react-router的几种配置方式详解
Jul 24 Javascript
详解VueJs中的V-bind指令
May 03 Javascript
js中arguments对象的深入理解
May 14 Javascript
微信小程序实现多选框功能的实例代码
Jun 24 Javascript
vue同个按钮控制展开和折叠同个事件操作
Jul 29 Javascript
微信小程序canvas实现签名功能
Jan 19 Javascript
多种JQuery循环滚动文字图片效果代码
Jun 23 #Javascript
三种AngularJS中获取数据源的方式
Feb 02 #Javascript
原生JS实现拖拽图片效果
Aug 27 #Javascript
基于jquery实现下拉框美化特效
Feb 02 #Javascript
AngularJS自动表单验证
Feb 01 #Javascript
javascript实现右侧弹出“分享到”窗口效果
Feb 01 #Javascript
AngularJS手动表单验证
Feb 01 #Javascript
You might like
PHP的PDO大对象(LOBs)
2019/01/27 PHP
laravel 解决路由除了根目录其他都404的问题
2019/10/18 PHP
javawscript 三级菜单的实现原理
2009/07/01 Javascript
IE6 弹出Iframe层中的文本框“经常”无法获得输入焦点
2009/12/27 Javascript
jquery动态加载select下拉框示例代码
2013/12/10 Javascript
php is_numberic函数造成的SQL注入漏洞
2014/03/10 Javascript
Bootstrap入门书籍之(零)Bootstrap简介
2016/02/17 Javascript
JS事件添加和移出的兼容写法示例
2016/06/20 Javascript
Bootstrap和Java分页实例第一篇
2016/12/23 Javascript
Vue 过渡实现轮播图效果
2017/03/27 Javascript
使用vue2.6实现抖音【时间轮盘】屏保效果附源码
2019/04/24 Javascript
JavaScript内置对象math,global功能与用法实例分析
2019/06/10 Javascript
vue中父子组件传值,解决钩子函数mounted只运行一次的操作
2020/07/27 Javascript
[01:12]DOTA2次级职业联赛 - Newbee.Y 战队宣传片
2014/12/01 DOTA
python 重定向获取真实url的方法
2018/05/11 Python
python文件操作之批量修改文件后缀名的方法
2018/08/10 Python
python3学生名片管理v2.0版
2018/11/29 Python
PyTorch之图像和Tensor填充的实例
2019/08/18 Python
python 实现检验33品种数据是否是正态分布
2019/12/09 Python
如何使用PyCharm将代码上传到GitHub上(图文详解)
2020/04/27 Python
Python requests.post方法中data与json参数区别详解
2020/04/30 Python
python调用API接口实现登陆短信验证
2020/05/10 Python
python3.x中安装web.py步骤方法
2020/06/23 Python
27个经典Linux面试题及答案,你知道几个?
2014/03/11 面试题
Prototype是怎么扩展DOM的
2014/10/01 面试题
英文求职信结束语大全
2013/10/26 职场文书
职业技术学校毕业生推荐信
2013/12/03 职场文书
cf收人广告词
2014/03/14 职场文书
艺术设计专业个人求职信
2014/04/10 职场文书
买卖车协议书
2014/04/21 职场文书
离婚协议书怎么写
2014/09/12 职场文书
婚礼父母答谢词
2015/01/04 职场文书
工作迟到检讨书范文
2015/05/06 职场文书
严以修身专题学习研讨会发言材料
2015/11/09 职场文书
Python中tkinter的用户登录管理的实现
2021/04/22 Python
React配置子路由的实现
2021/06/03 Javascript