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 相关文章推荐
js监听表单value的修改同步问题,跨浏览器支持
Dec 31 Javascript
JavaScript初学者需要了解10个小技巧
Aug 25 Javascript
JavaScript中判断变量是数组、函数或是对象类型的方法
Feb 25 Javascript
浅谈json取值(对象和数组)
Jun 24 Javascript
Node.js与Sails redis组件的使用教程
Feb 14 Javascript
AngularJS表格样式简单设置方法示例
Mar 03 Javascript
BootStrap+Mybatis框架下实现表单提交数据重复验证
Mar 23 Javascript
Angular2学习教程之TemplateRef和ViewContainerRef详解
May 25 Javascript
javascript代码优化的8点总结
Jan 29 Javascript
微信小程序之几种常见的弹框提示信息实现详解
Jul 11 Javascript
node.js中process进程的概念和child_process子进程模块的使用方法示例
Feb 11 Javascript
Javascript如何实现扩充基本类型
Aug 26 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实现按文件名搜索文件的远程文件查找器
2014/05/10 PHP
php调用shell的方法
2014/11/05 PHP
php中smarty变量修饰用法实例分析
2015/06/11 PHP
详解 PHP加密解密字符串函数附源码下载
2015/12/18 PHP
理解PHP中的Session及对Session有效期的控制
2016/01/08 PHP
php mysql获取表字段名称和字段信息的三种方法
2016/11/13 PHP
PHP mongodb操作类定义与用法示例【适合mongodb2.x和mongodb3.x】
2018/06/16 PHP
PHP一致性hash分布式算法封装类定义与用法示例
2018/08/04 PHP
jquery 漂亮的删除确认和提交无刷新删除示例
2013/11/13 Javascript
text-align:justify实现文本两端对齐 兼容IE
2015/08/19 Javascript
JavaScript中的数据类型转换方法小结
2015/10/26 Javascript
jQuery实现打开页面渐现效果示例
2016/07/27 Javascript
javascript 解决浏览器不支持的问题
2016/09/24 Javascript
JavaScript和jQuery制作光棒效果
2017/02/24 Javascript
详解nodeJS中读写文件方法的区别
2017/03/06 NodeJs
Koa2微信公众号开发之消息管理
2018/05/16 Javascript
vue实现滑动切换效果(仅在手机模式下可用)
2020/06/29 Javascript
在vue-cli创建的项目中使用sass操作
2020/08/10 Javascript
[01:18:36]LGD vs VP Supermajor 败者组决赛 BO3 第一场 6.10
2018/07/04 DOTA
使用Python的Treq on Twisted来进行HTTP压力测试
2015/04/16 Python
Python操作Sql Server 2008数据库的方法详解
2018/05/17 Python
python实现字符串加密 生成唯一固定长度字符串
2019/03/22 Python
python 机器学习之支持向量机非线性回归SVR模型
2019/06/26 Python
PIL包中Image模块的convert()函数的具体使用
2020/02/26 Python
Python decimal模块使用方法详解
2020/06/08 Python
解决TensorFlow程序无限制占用GPU的方法
2020/06/30 Python
Anaconda的安装与虚拟环境建立
2020/11/18 Python
Python如何实现Paramiko的二次封装
2021/01/30 Python
FORZIERI澳大利亚站:全球顶级奢华配饰精品店
2016/12/31 全球购物
JBL英国官网:JBL UK
2018/07/04 全球购物
国家励志奖学金个人先进事迹材料
2014/05/04 职场文书
慰问信范文
2015/02/14 职场文书
初中历史教学反思
2016/02/19 职场文书
商业计划书如何写?关键问题有哪些?
2019/07/11 职场文书
Ajax是什么?Ajax高级用法之Axios技术
2021/04/21 Javascript
springboot集成springCloud中gateway时启动报错的解决
2021/07/16 Java/Android