[Angular Tutorial] 7-XHRs & Dependency Injection
我们受够了在应用中用硬编码的方法嵌入三部电话!现在让我们用Angular内建的叫做$http的服务来从我们的服务器获取更大的数据集吧。我们将会使用Angular的依赖注入来为PhoneListCtrl控制器提供服务。
·现在我们有一个20部电话的列表,它们都是从服务器加载而来。
最重要的变化列举如下,当然您也可以点击这里在GitHub上查看所有的不同。
数据
你项目中的app/phones/phones.json文件是一个使用了JSON格式的一个更大的电话数据集合。
下面是一个文件的样本:
[
{
"age": 13,
"id": "motorola-defy-with-motoblur",
"name": "Motorola DEFY\u2122 with MOTOBLUR\u2122",
"snippet": "Are you ready for everything life throws your way?"
...
},
...
]
组件控制器
我们将会在控制器中使用Anglular的$http服务来想服务端发送一个HTTP请求,以此来从app/phones/phones.json文件中获取数据。$http仅仅是Angular自带的几个服务之一,这些服务在web应用中处理公共的操作。当您需要这些服务的时候,Angular将为您注入它们。
服务是由Angular的DI子系统管理的,依赖注入可以使您的web应用同时保持良好的组织结构(比如:展示层,数据层和控制器的独立组成)和松耦合(各组件间的依赖是由DI子系统而不是由组件自身决定的)。
app/phone-list/phone-list.component.js:
angular.
module('phoneList').
component('phoneList', {
templateUrl: 'phone-list/phone-list.template.html',
controller: function PhoneListController($http) {
var self = this;
self.orderProp = 'age'; $http.get('phones/phones.json').then(function(response) {
self.phones = response.data;
});
}
});
$http向我们的web服务端发送一个HTTP GET请求,请求phones.json(该url相对于我们的index.html文件)。服务端通过返回JSON文件中的数据作为响应(改响应可能刚好被后端服务器动态生成。对于浏览器和我们的应用来说,它们看起来是一样的。为了简单起见,我们在这篇tutorial中使用了一个JSON文件)。
$http服务通过then()方法返回一个promise对象。我们调用这个方法来处理异步相应并且将电话数据分配给控制器中一个叫做phones的属性。注意到Angular已经检测到了JSON响应并且为我们解析它,将其导入response对象(被传递至我们的回调函数)中的data属性!
因为我们在一个回调函数中为phones属性分配任务,而this的值在此处没有被定义,所以我们也会引进一个叫做self的局部变量来指向控制器实体。
为了在Angular中使用服务,您仅仅需要声明您需要的依赖的名字,并将其作为控制器构造函数的参数,如下所示:
function PhoneListController($http) {...}
控制器被构建时,Angular的依赖注入器为您的控制器提供服务。依赖注入器也会注意创建任何这个服务需要的传递性依赖(服务经常依赖于其他服务)。
注意到这些参数的名字是非常重要的,因为注入器将使用它们来寻找依赖。
$-前缀命名规范
您可以创建您自己的服务,我们会在接下来的步骤中做这件事。正如命名规范,Angular内置的服务,Scope方法和少量其他的Angular API 都在它们的名字前都有一个$前缀。
$前缀是Angular提供的服务的命名空间。为了防止冲突,您最好避免以一个$为前缀来命名您的服务和数据模型。
如果您检查一个Scope,您可能会注意到一些属性以$$作为前缀。这些属性被认为是私有的(private),并且不应当被获取或修改。
一点关于压缩的笔记
由于Angular是通过控制器构造函数的参数的名字来推断控制器的依赖的,如果您想要压缩PhoneListContrller控制器的js代码,所有的函数参数也会被压缩,那么依赖注入器将不会被服务正确识别。
我们可以通过用依赖的名字来注释函数来解决这个问题,用string数组提供,这不会被压缩,有两种方法来提供注入注释:
·在控制器中创建一个$inject属性来记录一个string的数组。该数组中的每一个string是将要注入服务的对应参数,在我们例子中,我们可以这样写:
function PhoneListController($http) {...}
PhoneListController.$inject = ['$http'];
...
.component('phoneList', {..., controller: PhoneListController});
·使用一个内联注释,而不是仅仅提供一个函数,而是提供一个数组,这个数组包含服务名称的列表,并且跟随函数本身。
function PhoneListController($http) {...}
...
.component('phoneList', {..., controller: ['$http', PhoneListController]});
上述两种方法都可以在任何能被Angular注入的函数中起作用,所以您的编程风格将决定您使用哪一种。
当使用第二种方法时,一种常见的做法是在注册控制器时将构造函数内联成一个匿名函数:
.component('phoneList', {..., controller: ['$http', function PhoneListController($http) {...}]});
继续下去,我们将在tutorial中使用内联方法。记住这个,让我们为我们的PhoneListController添加注释:
app/phone-list/phone-list.component.js
angular.
module('phoneList').
component('phoneList', {
templateUrl: 'phone-list/phone-list.template.html',
controller: ['$http',
function PhoneListController($http) {
var self = this;
self.orderProp = 'age'; $http.get('phones/phones.json').then(function(response) {
self.phones = response.data;
});
}
]
});
实验
在phone-list.template.html的底部,添加<pre>{{$ctrl.phones | filter:$ctrl.query | orderBy:$ctrl.orderProp | json}}</pre>绑定来看看以JSON格式展示的电话列表。
在PhoneListController控制器中,可以做限制只返回第1到第5部电话的数据的预处理,在$http回调中使用如下代码:
self.phones = response.data.slice(0, 5);
总结
现在您已经知道使用Angular 服务是多么容易了吧(多亏Angular的依赖注入)。进入第八步,您将添加一些电话的略图和一些链接。
[Angular Tutorial] 7-XHRs & Dependency Injection的更多相关文章
- ANGULAR 2 BITS: UNIFIED DEPENDENCY INJECTION
Angular 1.x has two APIs for injecting dependencies into a directive. These APIs are not interchange ...
- [Angular] Communicate Between Components Using Angular Dependency Injection
Allow more than one child component of the same type. Allow child components to be placed within the ...
- [Angular] Component's dependency injection
An Angular service registered on the NgModule is globally visible on the entire application. Moreove ...
- [Angular Tutorial]PhoneCat Tutorial App
(注:曾经在<不敢止步>一书中看到学到一个观点,作者认为学习一门技术最好的方法就是翻译某部领域书籍.这里我决定做一次尝试,接下来花1个月左右时间,将Angular Tutorial Pho ...
- 依赖注入 | Dependency Injection
原文链接: Angular Dependency Injection翻译人员: 铁锚翻译时间: 2014年02月10日说明: 译者认为,本文中所有名词性的"依赖" 都可以理解为 & ...
- [Angular Tutorial] 6-Two-way Data Binding
在这一步中,您将会添加一个新特性来使得您的用户可以控制电话列表中电话的顺序,动态改变顺序是由创建一个新的数据模型的特性实现的,将它和迭代器绑定在一起,并且让数据绑定神奇地处理下面的工作. ·除了搜索框 ...
- Dependency Injection in ASP.NET Web API 2 Using Unity
What is Dependency Injection? A dependency is any object that another object requires. For example, ...
- AngularJs学习笔记--Dependency Injection(DI,依赖注入)
原版地址:http://code.angularjs.org/1.0.2/docs/guide/di 一.Dependency Injection(依赖注入) 依赖注入(DI)是一个软件设计模式,处理 ...
- Dependency Injection in ASP.NET Web API 2
What is Dependency Injection? A dependency is any object that another object requires. For example, ...
- .NET编程5月小结 - Blazor, Unity, Dependency Injection
本文是我在5月份看到的一些有趣的内容的集合.在这里你可以找到许多有关Blazor.ASPNET Core的学习资源和示例项目,有关在Unity中使用Zenject进行单元测试的博客,有关Unity项目 ...
随机推荐
- 笔记整理--Http-Cookie
如何设置一个永远无法删除的Cookie -- 系统架构 -- IT技术博客大学习 -- 共学习 共进步! - Google Chrome (2013/6/20 9:46:38) 如何设置一个永远无法删 ...
- 在 Linux 系统中安装Load Generator ,并在windows 调用方法
在 Linux 系统中安装Load Generator ,并在windows 调用 由于公司需要测试系统的最大用户承受能力,所以需要学习使用loadrunner.在安装的时候碰到了不少问题,所以写下此 ...
- 未能读取并闩锁页 (1:xxxxx)(用闩锁类型 SH)
设置数据库为紧急模式 停掉SQL Server服务: 把应用数据库的数据文件XXX_Data.mdf移走: 重新建立一个同名的数据库XXX: 停掉SQL服务: 把原来的数据文件再覆盖回来: 运行以下语 ...
- listview的简单封装
package com.itheima.googleplay.ui.view; import android.content.Context; import android.graphics.Colo ...
- 认识和选用常用的几种 GPRS 模块(转)
源:http://blog.sina.com.cn/s/blog_4d80055a0100e8kr.html 我在这里把常见的GPRS模块分成3种: (1)GPRS DTU(GPRS数传单元,常称GP ...
- 素数个数的位数<Math>
小明是一个聪明的孩子,对数论有着很浓烈的兴趣.他发现求1到正整数10^n (10的n次方)之间有多少个素数是一个很难的问题,该问题的难点在于决定于10^n 值的大小. 告诉你n的值,并且用ans表示小 ...
- PAT (Advanced Level) 1077. Kuchiguse (20)
最长公共后缀.暴力. #include<cstdio> #include<cstring> #include<cmath> #include<vector&g ...
- 时间轴CSS的Demo
一.CSS代码(HTML5支持) /*time-line.css*/ .timeline { position: relative; padding: 20px 0 20px; list-style: ...
- w3school之JavaScript学习笔记
在前端测试过程中,少不了听到开发说到JS,JS在webJavaScript 是浏览器脚本语言(简称JS),主要用来向HTML页面添加交互行为. 学习网址:http://www.w3school.com ...
- SQL复习五(索引)
SQL索引在数据库优化中占有一个非常大的比例, 一个好的索引的设计,可以让你的效率提高几十甚至几百倍,在这里将带你一步步揭开他的神秘面纱. 1.1 什么是索引? SQL索引有两种,聚集索引和非聚集索引 ...