`
天梯梦
  • 浏览: 13753748 次
  • 性别: Icon_minigender_2
  • 来自: 洛杉矶
社区版块
存档分类
最新评论

七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX

 
阅读更多

AngularJS学习列表:七步走 Angular.js 从菜鸟到专家 (系列列表)

 

上一篇之后,这是"AngularJS - 七步从菜鸟到专家"系列的第三篇。

在第一篇,我们展示了如何开始搭建一个AngularaJS应用。第二篇我们讨论了scope和 $scope 的功能。

通过这整个系列的教程,我们会开发一个NPR(美国全国公共广播电台)广播的音频播放器,它能显示Morning Edition节目里现在播出的最新故事,并在我们的浏览器里播放。完成版的Demo可以看这里。

 

第三部分 数据绑定

通过把一个文本输入框绑定到person.name属性上,就能把我们的应用变得更有趣一点。这一步建立起了文本输入框跟页面的双向绑定。

七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX
七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX

在 这个语境里“双向”意味着如果view改变了属性值,model就会“看到”这个改变,而如果model改变了属性值,view也同样会“看到”这个改 变。Angular.js 为你自动搭建好了这个机制。如果你好奇这具体是怎么实现的,请看我们之后推出的一篇文章,其中深入讨论了 digest_loop 的运作。

 

要建立这个绑定,我们在文本输入框上使用ng-model 指令属性,像这样:

<div ng-controller="MyController">
    <input type="text" ng-model="person.name" placeholder="Enter your name" />
    <h5>Hello {{ person.name }}</h5>
</div>

 

现在我们建立好了一个数据绑定(没错,就这么容易),来看看view怎么改变model吧:

 

试试看:

七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX
七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX

当 你在文本框里输入时,下面的名字也自动随之改变,这就展现了我们数据绑定的一个方向:从view到model。我们也可以在我们的(客户端)后台改变 model,看这个改变自动在前端体现出来。要展示这一过程,让我们在  MyController 的model里写一个计时器函数, 更 新 $scope 上的一个数据。下面的代码里,我们就来创建这个计时器函数,它会在每秒计时(像钟表那样),并更新 $scope 上的clock变量 数据:

app.controller('MyController', function($scope) 
{  
    $scope.person = { name: "Ari Lerner" };  
    var updateClock = function() {    $scope.clock = new Date();  };  
    var timer = setInterval(function() {    $scope.$apply(updateClock);  }, 1000);  
    updateClock();
});

 

可以看到,当我们改变modelclock变量的数据,view会自动更新来反映此变化。用大括号我们就可以很简单地让clock变量的值显示在view里:

<div ng-controller="MyController">
    <h5>{{ clock }}</h5>
</div>

 

请看:

{{ clock }}

 

互动

前面我们把数据绑定在了文本输入框上。请注意, 数据绑定并非只限于数据,我们还可以利用绑定调用 $scope 中的函数(这一点之前已经提到过)。

 

对 按钮、链接或任何其他的DOM元素,我们都可以用另一个指令属性来实现绑定:ng-click 。这个 ng-click 指令将DOM元素的鼠标点击事 件(即 mousedown 浏览器事件)绑定到一个方法上,当浏览器在该DOM元素上鼠标触发点击事件时,此被绑定的方法就被调用。跟上一个例子相似, 这个绑定的代码如下:

<div ng-controller="DemoController">
    <h4>The simplest adding machine ever</h4>
    <button ng-click="add(1)" class="button">Add</button>
    <button ng-click="subtract(1)" class="button">Subtract</button>
    <h4>Current count: {{ counter }}</h4>
</div>

 

不论是按钮还是链接都会被绑定到包含它们的DOM元素的controller所有的 $scope 对象上,当它们被鼠标点击,Angular就会调用相应的方法。注意当我们告诉Angular要调用什么方法时,我们将方法名写进带引号的字符串里。

app.controller('DemoController', function($scope) 
{
    $scope.counter = 0;
    $scope.add = function(amount) { $scope.counter += amount; };
    $scope.subtract = function(amount) { $scope.counter -= amount; };
});

 

 请看:

七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX
七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX

 

myApp中的数据绑定和AJAX

互动

在上一篇的例子中,我们对view的一个按钮进行了刚才学到的数据绑定,给play按钮绑定了 PlayerController 的play方法(同样的,还给stop按钮绑定了stop方法)。

 

AJAX

在 上一篇教程里,我们引用的是一个存储在本地的音频文件,它给我们的是一个静态的NPR文件,而不是一个动态的NPR feed。在我们的NPR应用里,我 们将用$http 来填充我们可播放的新闻文件的列表。Angular.js原生支持AJAX,由此我们就获得了与一个或多个服务器来回发送请求的能力。 这个能力对我们要创建的这种客户端应用来说是至关重要的,因为这种应用需要跟服务器交流,获取和更新数据。Angular.js通过一个服务来支持 AJAX(在之后的章节我们会讨论这个服务),这个服务就叫做 $http 服务。所有Angular.js的核心服务都用 $ 前缀,这点在之前 的 $scope  服务里我们已经见过了。这个 $http 服务极其灵活,给了我们很多种方式来调用AJAX服务。为保证本教程简单易懂,我们专注于 最简单的方式。在以后更高级的章节里我们会深入介绍 $http 服务。在深入过多细节之前,让我们先来用 $http 服务创建一个请求:

$http({  
    method: 'JSONP',  
    url: 'http://api.openbeerdatabase.com/v1/beers.json?callback=JSON_CALLBACK'
}).success(function(data, status, headers, config) {  
    // data contains the response  
    // status is the HTTP status  
    // headers is the header getter function  
    // config is the object that was used to create the HTTP request
}).error(function(data, status, headers, config) {});

 

试试看:

七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX
七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX

$http 服务是Angular.js的核心服务之一,它帮助我们通过XMLHttpRequest对象或JSONP与远程HTTP服务进行交流。

 

注意, 像上面例子中那样,原封不动加上以下字符串 callback=JSON_CALLBACK ,Angular.js就会负责为你处理JSONP请求,将 JSON_CALLBACK 替换成一个合适的回调函数。

 

$http 服务是这样一个函数:它接受一个设置对象,其中指定了如何创建HTTP请求;它将返回一个承诺(*参考JavaScript异步编程的promise模式),其中提供两个方法: success方法和error方法。

 

要取得可播放的音频文件列表,让我们向NPR的API发送一个请求。首先,你需要倒NPR注册以取得一个API key。到它们的网站 http://www.npr.org/templates/reg/ 去。(作者在这里用Angular.js做了一个用iFrame加载的NPR注册表单,见下图,或者直接前往英文原文查看)。

 

七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX
七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX

记下你的API key,我们马上就会用到它。现在我们要设置我们的PlayController 来调用 $http 服务,取回音频文件。

 

像 我们刚才做的那样,让我们调用 $http 服务来创建一个请求,这一次是为了取得所有音频文件。我们想让这个服务在controller实例化时启动, 所以我们只需要把这个方法直接放在controller函数里(这个函数在controller被创建时就会被调用),像这样:

var apiKey = 'YOUR_KEY',
nprUrl = 'http://api.npr.org/query?id=61&fields=relatedLink,title,byline,text,audio,image,pullQuote,all&output=JSON';

app.controller('PlayerController', function($scope, $http) 
{
    // Hidden our previous section's content
    // construct our http request
    $http({
        method: 'JSONP',
        url: nprUrl + '&apiKey=' + apiKey + '&callback=JSON_CALLBACK'
    }).success(function(data, status){
        // Now we have a list of the stories (data.list.story)
        // in the data object that the NPR API
        // returns in JSON that looks like:
        // data: { "list": {
        //   "title": ...
        //   "story": [
        //     { "id": ...
        //       "title": ...
    }).error(function(data, status) {
        // Some error occurred
    });
});

 

现在我们在success函数的data里有了一个音频文件的列表。在success回调函数里,把这个列表存储在 $scope 对象,这样我们就简单地把它绑定在了 $scope 对象上:

// from above
}).success(function(data, status) {
    // Store the list of stories on the scope
    // from the NPR API response object (described above)
    $scope.programs = data.list.story;
}).error(function(data, status) {
    // Some error occurred

 

现在,跟刚才一样, 只需在view里访问programs,我们就能在view里访问这个data。你看,使用Angular.js的一个好处就是,当承诺模式返回成功结果时,Angular.js就会自动把这个结果填进你的view里。

<div ng-controller="PlayerController">
    {{ programs }}
</div>

 

试试看:

_4NF@PJ182[352{D2DOSZ7I

在下一章里,我们会讨论怎么在我们的view里有意义地展示这个data对象,使用一些Angular.js自带的指令(和更多的一点什么)。

 

本系列的官方代码库可从github上下载:

https://github.com/auser/ng-newsletter-beginner-series.

 

要将这个代码库保存到本地,请先确保安装了git,clone此代码库,然后check out其中的part3分支:

git clone https://github.com/auser/ng-newsletter-beginner-series.git 
git checkout -b part3

 

 

下载:ng-newsletter-beginner-series-part3

原文链接:http://www.ng-newsletter.com/posts/beginner2expert-data-binding.html

译文链接:http://blog.jobbole.com/48780/

AngularJS学习列表:七步走 Angular.js 从菜鸟到专家 (系列列表)

下一篇:七步从AngularJS菜鸟到专家(4和5):指令和表达式

 

本文转自:七步从Angular.JS菜鸟到专家(3):数据绑定和AJAX

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    Angular.js v1.8.3.zip

    - **双数据绑定**:Angular.js的一大特色是双向数据绑定,它自动同步模型和视图,使得UI和后台数据始终保持一致。 - **依赖注入**:Angular.js的DI系统允许开发者轻松地在组件之间共享服务,降低了代码的耦合度。 ...

    angular.min.Js

    angular.min.Js

    angular.js 本地引用

    在前端开发领域,AngularJS(通常简称为Angular.js)是一个非常流行且强大的JavaScript框架,由Google维护。这个框架主要用于构建动态、单页Web应用程序(SPA),它提供了丰富的功能来简化前端开发过程,包括数据...

    angular.js-master.zip

    AngularJS 是一个强大的前端JavaScript框架,由Google维护,主要用于构建单页应用(SPA,Single Page Applications)。这个"angular.js-master.zip"压缩包很可能是AngularJS的源码仓库,特别是1.3版本的一个分支或...

    基于angular.js的WUI-DatePicker日期选择器插件

    Angular.js 是一个强大的前端JavaScript框架,它提供了丰富的功能和灵活性,用于构建动态、数据驱动的Web应用程序。而WUI-DatePicker是一款基于Angular.js开发的日期选择器插件,专为提高用户体验而设计,提供了多种...

    angular.js

    Angular.js通过双向数据绑定将模型与视图自动同步,任何一方的改变都会反映到另一方。 2. **视图(View)**:是用户看到和与之交互的界面。视图中的元素可以通过Angular的指令(Directives)进行扩展,这些指令允许...

    angular.min.v125.rar(亲测可用)

    4. **服务**:Angular.js提供了一系列内置服务(如$http、$scope、$location等),同时支持自定义服务,用于在应用的不同部分之间共享功能和数据。 5. **过滤器**:过滤器用于格式化数据,如日期、货币等,可以方便...

    angular.js资料

    而使用Angular.js,可以通过数据绑定和指令,只更新页面的一部分,而不是整个页面,从而提高响应速度和用户体验。 在学习Angular.js的过程中,开发者可以了解到如何通过使用ng-controller指令来指定应用中的控制器...

    angular.js-1.6.9

    AngularJS,作为一款由Google维护的前端JavaScript框架,是MVVM(Model-View-ViewModel)模式的杰出代表,以其强大的数据绑定、依赖注入和模块化功能深受开发者喜爱。在1.6.9这个版本中,我们看到对稳定性和性能的一...

    angular.js后台管理系统.zip

    - **双向数据绑定**:Angular.js通过$digest循环自动同步模型和视图,确保数据的实时更新。 - **指令系统**:自定义DOM元素和属性,扩展HTML功能,如ng-repeat用于循环渲染列表,ng-if进行条件判断等。 - **依赖...

    Angular权威指南 英文名:Manning.Angular.in.Action 出书日期:2018.3 PDF高清带书签

    Angular的特点包括组件化架构、双向数据绑定、依赖注入等高级特性,这些使得开发者能够高效地构建复杂的应用程序。 #### 四、Angular中的组件通信详解 Angular应用程序是围绕着组件构建的,这些组件之间通过特定的...

    Angular.js.zip

    Angular.js,通常简称为Angular,是由Google维护的一个开源JavaScript框架,用于构建单页应用程序(SPA)。这个框架的主要目标是简化前端开发,通过提供强大的数据绑定和依赖注入机制,让开发者可以更加专注于应用...

    基于angular.js日期选择器.zip

    首先,我们要理解Angular.js中的`ngModel`指令,它是数据绑定的核心。在日期选择器中,`ngModel`将被用来绑定用户选择的日期或时间到我们的应用程序模型,这样我们就可以在控制器中访问并处理这些值。例如,我们可以...

    angular.js-master

    - **单向数据绑定**:从模型到视图的方向,模型的改变会实时反映到视图上。 - **双向数据绑定**:模型和视图可以互相影响,当视图变化时,模型也会相应更新。 ### 7. 服务(Services) - **$http服务**:用于发起...

    angular-1.8.0.zip

    1. **数据绑定**:双向数据绑定是Angular.js的核心特性,使得视图和模型之间的数据自动同步,减少了手动DOM操作。 2. **依赖注入**:Angular.js通过依赖注入(DI)机制管理对象的生命周期和依赖关系,使得代码可...

    前端项目-c3-angular.zip

    集成C3.js到AngularJS项目中,开发者可以利用AngularJS的数据绑定特性,将数据模型直接绑定到C3.js图表上,实现数据的实时更新。这极大地提高了开发效率,并且提供了更加灵活的交互体验。通过使用这个项目,开发者...

    angular.js-1.3.0

    3. **双向数据绑定**:AngularJS的双向数据绑定是其标志性的功能,允许视图和模型之间的实时同步。在1.3.0版本中,这一特性得到了增强,能够更好地处理复杂的数据结构和深层对象的变更。 4. **模块化**:AngularJS...

    angular.min.js 1.4.6下载

    AngularJS 是一个 JavaScript 框架。它可通过 &lt;script&gt; 标签添加到 HTML 页面。

    angular-flot, angular.js 和Flot图表库之间的绑定.zip

    angular-flot, angular.js 和Flot图表库之间的绑定 角 flot 包装Flotcharts的一个 Angular 指令。安装这里库是作为 Bower 组件和NPM模块提供的:Bower: bower install angular-flotnpm install

    angular.min.js

    angular.min.js 1.5.8

Global site tag (gtag.js) - Google Analytics