AngularJS学习--- AngularJS中XHR(AJAX)和依赖注入(DI) step5

前言:本文接前一篇文章,主要介绍什么是XHR,AJAX,DI,angularjs中如何使用XHR和DI.

1.切换工具目录

git checkout -f step-5 #切换分支
npm start #启动项目

2.什么是XHR和依赖注入(Dependency Injection)?


1)什么是XHR?


XHR是XMLHttpRequest的简称,XMLHttpRequest 用于在后台与服务器交换数据,主要是为了实现在不重新加载整个网页的情况下,对网页的某部分进行更新。简单说,浏览器中URL不变,但页面中局部元素有改变.

XHR有两个方法open(method,url,async)和send(string);

AJAX 指的是异步 JavaScript 和 XML(Asynchronous JavaScript and XML)。

XMLHttpRequest 对象如果要用于 AJAX 的话,其 open()
方法的 async 参数必须设置为 true,所以可以看得出来AJAX是XHR中的一种,只不过是异步加载数据.

2)什么是依赖注入(Dependency Injection)?

依赖注入(Dependency Injection)即控制反转(Inversion of
Control),是软件工程领域的一种设计模式,主要用来解决代码的耦合问题,也是轻量级的Spring框架的核心.

简单说就是一段代码想共用,不想手工插入到指定位置,想注入进去,这里就可以使用DI(Dependency Injection).

其实现方式如下:

方式1 (基于接口):
可服务的对象需要实现一个专门的接口,该接口提供了一个对象,可以从用这个对象查找依赖(其它服务)。早期的容器Excalibur使用这种模式。

方式2 (基于setter):
通过JavaBean的属性(setter方法)为可服务对象指定服务。HiveMind和Spring采用这种方式。

方式3 (基于构造函数):
通过构造函数的参数为可服务对象指定服务。PicoContainer只使用这种方式。HiveMind和Spring也使用这种方式。

依赖注入在Java后台中用到的相对较多.

3.AngularJS中的XHR(AJAX)


angularjs中使用$http来发出请求,接受返回过来的数据.主要支持以下几种方法:

用法示例:

 $http.get(‘/someUrl‘).success(successCallback);
$http.post(‘/someUrl‘, data).success(successCallback);

其中关于jsonp的方法要注意一下,其用法如下:

jsonp(url, [config]);官方api文档为https://docs.angularjs.org/api/ng/service/$http#jsonp .

4.实例介绍:


app/index.html

<!doctype html>
<html lang="en" ng-app="phonecatApp">
<head>
<meta charset="utf-8">
<title>Google Phone Gallery</title>
<link rel="stylesheet" href="../bower_components/bootstrap/dist/css/bootstrap.css">
<link rel="stylesheet" href="css/app.css">
<script src="../bower_components/angular/angular.js"></script>
<script src="js/controllers.js"></script>
</head>
<body ng-controller="PhoneListCtrl">

<div class="container-fluid">
<div class="row">
<div class="col-md-2">
<!--Sidebar content-->

Search: <input ng-model="query">
Sort by:
<select ng-model="orderProp">
<option value="name">Alphabetical</option>
<option value="age">Newest</option>
</select>

</div>
<div class="col-md-10">
<!--Body content-->

<ul class="phones">
<li ng-repeat="phone in phones | filter:query | orderBy:orderProp">
<span>{{phone.name}}</span>
<p>{{phone.snippet}}</p>
</li>
</ul>

</div>
</div>
</div>

</body>
</html>

数据源:


angular-phonecat/app/phones$ cat phones.json


[
{
"age": 0,
"id": "motorola-xoom-with-wi-fi",
"imageUrl": "img/phones/motorola-xoom-with-wi-fi.0.jpg",
"name": "Motorola XOOM\u2122 with Wi-Fi",
"snippet": "The Next, Next Generation\r\n\r\nExperience the future with Motorola XOOM with Wi-Fi, the world‘s first tablet powered by Android 3.0 (Honeycomb)."
},

{
......
}
]

数据源格式是如上面所述的json格式的数据,主要包括age,id,imageUrl,name,snippet5种属性;

Controller(控制器)

app/js/controllers.js:


var phonecatApp = angular.module(‘phonecatApp‘,[]);

phonecatApp.controller(‘PhoneListCtrl‘,function($scope, $http){
$http.get(‘phones/phones.json‘).success(function(data){
$scope.phones =
data;});

$scope.orderProp =‘age‘;});

很显示这里使用的是$http.get()方法去取的数据,跟jquery里面的get方法很类似(

$(selector).get(url,data,success(response,status,xhr),dataType)//这里jquery中的get方法

),本例中url为‘phones/phones.json‘,如果返回数据成功,那么将返回会值赋给$scope.phones,同时$scope.orderProp的默认值赋给‘age‘,默认按age的大小来排序.

其原理如下图所示:

‘$‘前缀命名


angularjs中对常用的方法,作用域等命名时一般会加上‘$‘,所以自己在创建方法或service时最好不要加上‘$‘,以免引起混淆.

压缩js代码产生的问题


因为AngularJS是通过控制器构造函数的参数名字来推断依赖服务名称,所有的参数也同时会被压缩,这时候依赖注入系统就不能正确的识别出服务了.

解决方法一:

  function PhoneListCtrl($scope, $http) {...}
PhoneListCtrl.$inject = [‘$scope‘, ‘$http‘];
phonecatApp.controller(‘PhoneListCtrl‘, PhoneListCtrl);

使用$inject方法将要做的赋值赋进去.

解决方法二:

 function PhoneListCtrl($scope, $http) {...}
phonecatApp.controller(‘PhoneListCtrl‘, [‘$scope‘, ‘$http‘, PhoneListCtrl]);

4.效果


注:效果跟之前差不多,只不过是数据是动态加载的了,而不是写死的,而获取数据的方法就是$http.get().

5.测试

test/unit/controllersSpec.js 


[email protected]:~/develop/angular-phonecat/test/unit$ cat controllersSpec.js
‘use strict‘;

/* jasmine specs for controllers go here */
describe(‘PhoneCat controllers‘, function() {

describe(‘PhoneListCtrl‘, function(){
var scope, ctrl, $httpBackend;

beforeEach(module(‘phonecatApp‘));
beforeEach(inject(function(_$httpBackend_, $rootScope, $controller) {
$httpBackend = _$httpBackend_;
$httpBackend.expectGET(‘phones/phones.json‘).
respond([{name: ‘Nexus S‘}, {name: ‘Motorola DROID‘}]);

scope = $rootScope.$new();
ctrl = $controller(‘PhoneListCtrl‘, {$scope: scope});
}));

it(‘should create "phones" model with 2 phones fetched from xhr‘, function() {
expect(scope.phones).toBeUndefined();
$httpBackend.flush();

expect(scope.phones).toEqual([{name: ‘Nexus S‘},
{name: ‘Motorola DROID‘}]);
});

it(‘should set the default value of orderProp model‘, function() {
expect(scope.orderProp).toBe(‘age‘);
});
});
});

测试结果:

[email protected]:~/develop/angular-phonecat$ npm run protractor
......
Finished in 5.241 seconds
2 tests, 5 assertions, 0 failures

注:

1).因为我们在测试环境中加载了Jasmineangular-mock.js,我们有了两个辅助方法,moduleinject,来帮助我们获得和配置注入器。用inject方法将$rootScope$controller$httpBackend服务实例注入到Jasmine的beforeEach函数里

2).调用$rootScope.$new()来为我们的控制器创建一个新的作用域

3).$httpBackend.flush() 来清空(flush)请求队列

4).expect是用来做验证的, expect(scope.orderProp).toBe(‘age‘);这个就是验证当前域下的默认排序orderProp是不是age.

AngularJS学习--- AngularJS中XHR(AJAX)和依赖注入(DI) step5

时间: 2024-10-25 11:35:29

AngularJS学习--- AngularJS中XHR(AJAX)和依赖注入(DI) step5的相关文章

AngularJs学习笔记6——四大特性之依赖注入

压缩工具:YUI-compressor 为了优化网页功能,对一些脚本文件进行压缩,比如:删除所有的注释和空格等,简化形参.但是AngularJs模块中可以声明多种组件,如控制器.指令.过滤器.服务等.创建这些模块组件对象时,构造函数是由AngularJS调用的,故不能像普通函数那样,声明任意的形参.使得压缩后的文件无法使用,这时候采用标记式和行内式的数组形式(注意顺序的对应关系),使得压缩后依然可以使用. 依赖:实现功能的时候,如果需要某些模块,模块就是需要的依赖 AngularJS会自动根据依

AngularJS学习--- AngularJS中数据双向绑定(two-way data-binding) orderBy step4

1.切换工作目录 git checkout step-4 #切换分支,切换到第4步 npm start #启动项目 2.代码 app/index.html Search: <input ng-model="query"> Sort by: <select ng-model="orderProp"> <option value="name">Alphabetical</option> <opti

AngularJS学习--- AngularJS中模板链接和图像 ng-src step6

接上一篇文章,本文将主要介绍angularjs中的模板链接,和图像显示? 首先,切换分支,启动项目: git checkout step-6 npm start 1.效果 相较于前一篇文章,明显感觉多了图片,那么这些图片是怎么加载进去的呢?这里图片各不一样,如果用传统的方式去加载图片可能要写很多代码,这里看一下angularjs是如何实现的?? 2.实现代码 app/index.html <ul class="phones"> <li ng-repeat="

Angularjs学习---angularjs环境搭建,ubuntu 12.04下安装nodejs、npm和karma

1.下载angularjs 进入其官网下载:https://angularjs.org/?,建议下载最新版的:https://ajax.googleapis.com/ajax/libs/angularjs/1.3.0-beta.7/angular.js 所有版本:https://code.angularjs.org/ 2.示例1 HelloWorld ! 新建一个helloworld.html <!doctype html> <html ng-app> <head> &

AngularJS应用开发思维之3:依赖注入

找不到的API? AngularJS提供了一些功能的封装,但是当你试图通过全局对象angular去 访问这些功能时,却发现与以往遇到的库大不相同. $http 比如,在jQuery中,我们知道它的API通过一个全局对象:$ 暴露出来,当你需要 进行ajax调用时,使用$.ajax()就可以了.这样的API很符合思维的预期. AngularJS也暴露了一个全局对象:angular,也对ajax调用进行封装提供了一个 $http对象,但是,但是,当你试图沿用旧经验访问angular.$http时,发

在mvc中使用Ninject进行依赖注入

说到依赖注入 ,首先要提到控制反转,控制反转(Inversion of Control,英文缩写为IoC)是一个重要的面向对象编程的原则,目的是来削减计算机程序的耦合问题控制反转一般分为两种类型, 依赖注入(Dependency Injection,简称DI)和依赖查找.两者的区别在于,前者是被动的接收对象,在类A的实例创建过程中即创建了依赖的B对象,通过类型或名称来判断将不同的对象注入到不同的 属性中,而后者是主动索取响应名称的对象,获得依赖对象的时间也可以在代码中自由控制.但是依赖注入的应用

Atitit js中的依赖注入di ioc的实现

全类名(FQCN)为标识符1 混合请求模式1 使用类内  builder  即可..2 Service locator method走ok拦2 Javascript技术栈中的四种依赖注入详解2 Js没有接口,anno 但是动态属性就是接口默认支持.Ducktype 随便注入即可.. 全类名(FQCN)为标识符 了弥补纯字符串请求模式中的类型安全问题,全类名(FQCN)请求模式就应运而生了.其思想便是,在向容器请求依赖对象的时候,不是通过字符串的标识 符.而是通过被请求的依赖的全类名来定位依赖.这

php中的数种依赖注入

经常看到却一直不甚理解的概念,依赖注入(DI)以及控制器反转(Ioc),找了几篇好的文章,分享一下. 自己理解的,依赖注入就是组件通过构造器,方法或者属性字段来获取相应的依赖对象. 举个现实生活中的例子来理解, 比如我要一把菜刀 如何获得1.可以自己造一把,对应new一个.2.可以找生产菜刀的工厂去买一把,对应工厂模式.3.可以打电话 让店家送货上门,对应依赖注入. 再比如我是一个演员,我不可能要求某个导演,我要演某某剧的男一号,相反,导演可以决定让谁来演.而我们的object就是这个演员. 注

话说 依赖注入(DI) or 控制反转(IoC)

首页 下载 扩展 应用 教程 代码 案例 资讯 讨论 全部 搜索 话说 依赖注入(DI) or 控制反转(IoC) 浏览:3641 发布日期:2014/03/20 分类:技术分享 科普:首先依赖注入和控制反转说的是同一个东西,是一种设计模式,这种设计模式用来减少程序间的耦合,鄙人学习了一下,看TP官网还没有相关的文章,就写下这篇拙作介绍一下这种设计模式,希望能为TP社区贡献一些力量. 首先先别追究这个设计模式的定义,否则你一定会被说的云里雾里,笔者就是深受其害,百度了N多文章,都是从理论角度来描