1.切换工作目录

  1. git checkout step-4 #切换分支,切换到第4步
  2. npm start #启动项目

2.代码

app/index.html

  1. Search: <input ng-model="query">
  2. Sort by:
  3. <select ng-model="orderProp">
  4. <option value="name">Alphabetical</option>
  5. <option value="age">Newest</option>
  6. </select>
  7.  
  8. <ul class="phones">
  9. <li ng-repeat="phone in phones | filter:query | orderBy:orderProp">
  10. {{phone.name}}
  11. <p>{{phone.snippet}}</p>
  12. </li>
  13. </ul>

app/controllers.js

  1. var phonecatApp = angular.module('phonecatApp', []);
  2.  
  3. phonecatApp.controller('PhoneListCtrl', function($scope) {
  4. $scope.phones = [
  5. {'name': 'Nexus S',
  6. 'snippet': 'Fast just got faster with Nexus S.',
  7. 'age': 1},
  8. {'name': 'Motorola XOOM™ with Wi-Fi',
  9. 'snippet': 'The Next, Next Generation tablet.',
  10. 'age': 2},
  11. {'name': 'MOTOROLA XOOM™',
  12. 'snippet': 'The Next, Next Generation tablet.',
  13. 'age': 3}
  14. ];
  15.  
  16. $scope.orderProp = 'age';
  17. });

3.效果

按字母排序:

按时间排序:

很明显,相较于step-3,step-4新增加了排序功能

4.原理说明

首先,添加了<select> 标签:

  1. <select ng-model="orderProp">
  2. <option value="name">Alphabetical</option>
  3. <option value="age">Newest</option>
  4. </select>

其次,在filter中添加了orderBy:

  1. <li ng-repeat="phone in phones | filter:query | orderBy:orderProp">
  2. {{phone.name}}
  3. <p>{{phone.snippet}}</p>
  4. </li>

所以,根据angularjs的思想,一是model改变(可能是用户手动选择下拉框导致的),那么根据数据绑定原则(data-binding),view也将适时进行改变.

orderBy api:https://docs.angularjs.org/api/ng/filter/orderBy

orderBy Usage(用法)

In HTML Template Binding(在HTML中的用法)

  1. {{ orderBy_expression | orderBy : expression : reverse}}

In JavaScript(在JS中的用法)

  1. $filter('orderBy')(array, expression, reverse)

上面的例子是在HTML中用的,默认string类型的数据是按照字母表中数据排序的,而number数字类型的数据是按照数字大小进行排序的.

如果想要倒序,那么可以在上面的option value='-name',加上一个'-'即可.

5.测试

  1. amosli@amosli-pc:~/develop/angular-phonecat$ npm run protractor
  2.  
  3. > angular-phonecat@0.0.0 preprotractor /home/amosli/develop/angular-phonecat
  4. > npm run update-webdriver
  5.  
  6. > angular-phonecat@0.0.0 preupdate-webdriver /home/amosli/develop/angular-phonecat
  7. > npm install
  8.  
  9. > angular-phonecat@0.0.0 postinstall /home/amosli/develop/angular-phonecat
  10. > bower install
  11.  
  12. > angular-phonecat@0.0.0 update-webdriver /home/amosli/develop/angular-phonecat
  13. > webdriver-manager update
  14.  
  15. selenium standalone is up to date.
  16. chromedriver is up to date.
  17.  
  18. > angular-phonecat@0.0.0 protractor /home/amosli/develop/angular-phonecat
  19. > protractor test/protractor-conf.js
  20.  
  21. ------------------------------------
  22. PID: 5265 (capability: chrome #1)
  23. ------------------------------------
  24.  
  25. Using ChromeDriver directly...
  26. ..
  27.  
  28. Finished in 5.033 seconds
  29. 2 tests, 5 assertions, 0 failures

这里执行的是端到端的测试,测试代码如下:

angular-phonecat/test/e2e/scenarios.js

 
 
 

requireJS(二)

摘要: 一、前言requireJS(一)本篇主要整理requirejs的一些用法,相对比较零散。实例目录二、优化requirejs建议我们给每一个模块书写一个js文件。但是这样会增加网站的http请求,这时可利用工具打包,详情求戳链接查看。三、关于define自定义模块之前说到自定义模块define()可接...阅读全文
 
posted @ 2014-05-07 10:59 cunjieliu 阅读(377) 评论(0) 编辑
 
摘要: 一、关于requirejsrequirejs是一个用于异步加载js模块的框架。详细介绍的请谷歌~二、HOW TO USE首先先去官网下载requirejs.js下来,再在自己的项目中引入1 注意到data-main这个属性,简单的理解就是一个入口函数,用来启动脚本的加载过程。tip:为了使这个文件加...阅读全文
 
posted @ 2014-05-06 15:11 cunjieliu 阅读(544) 评论(0) 编辑

AngularJS中数据双向绑定(two-way data-binding)的更多相关文章

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

    1.切换工作目录 git checkout step- #切换分支,切换到第4步 npm start #启动项目 2.代码 app/index.html Search: <input ng-mo ...

  2. vue中数据双向绑定的实现原理

    vue中最常见的属v-model这个数据双向绑定了,很好奇它是如何实现的呢?尝试着用原生的JS去实现一下. 首先大致学习了解下Object.defineProperty()这个东东吧! * Objec ...

  3. vue中数据双向绑定注意点

    最近一个vue和element的项目中遇到了一个问题: 动态生成的对象进行双向绑定是失败 直接贴代码: <el-form :model="addClass" :rules=& ...

  4. angularJs实现数据双向绑定的原理

    angular1.x在指定的事件触发时(比如dom事件,xhr响应事件,浏览器定位变更事件,定时器事件),通过脏值检测的方式比对数据是否有变更,来决定是否更新视图. angular2使用了zone.j ...

  5. 原生js实现数据双向绑定

    最近接触了vue,在谈到vue等等的mvvm框架之前,先了解什么是数据双向绑定以及如何利用原生JS实现数据双向绑定 单向数据绑定 指先把模板写好,然后把模板和数据(数据可能来自后台)整合到一起形成HT ...

  6. 数据双向绑定页面无反应(angularjs)

    问题引入 使用 angularjs进行过一段时间的开发后,基本上都会遇到一个这样的坑:页面进行了双向数据绑定,控制层的数据也已经改变了,但是视图层的数据却没有改变. 其实造成这个问题的原因大致分为以下 ...

  7. 我的angularjs源码学习之旅3——脏检测与数据双向绑定

    前言 为了后面描述方便,我们将保存模块的对象modules叫做模块缓存.我们跟踪的例子如下 <div ng-app="myApp" ng-controller='myCtrl ...

  8. 如何在原生微信小程序中实现数据双向绑定

    官网:https://qiu8310.github.io/minapp/ 作者:Mora 在原生小程序开发中,数据流是单向的,无法双向绑定,但是要实现双向绑定的功能还是蛮简单的! 下文要讲的是小程序框 ...

  9. Jquery实现数据双向绑定(赋值和取值),类似AngularJS

    <!DOCTYPE html> <html> <head> <meta name="viewport" content="wid ...

随机推荐

  1. Android IPC通信和AIDL技术应用

    首先我们了解一下 IPC和AIDL IPC:进程间通信 AIDL:Android Interface Definition Language,即Android接口定义语言. 为什么使用: Androi ...

  2. 二叉搜索树(Binary Search Tree)--C语言描述(转)

    图解二叉搜索树概念 二叉树呢,其实就是链表的一个二维形式,而二叉搜索树,就是一种特殊的二叉树,这种二叉树有个特点:对任意节点而言,左孩子(当然了,存在的话)的值总是小于本身,而右孩子(存在的话)的值总 ...

  3. 设计模式之享元模式(Flyweight)摘录

    23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于怎样创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而 ...

  4. 《学习opencv》笔记——矩阵和图像处理——cvAnd、cvAndS、cvAvg and cvAvgSdv

    矩阵和图像的操作 (1)cvAnd函数 其结构 void cvAnd( //将src1和src2按像素点取"位与运算" const CvArr* src1,//第一个矩阵 cons ...

  5. ABP领域层——领域事件(Domain events)

    ABP领域层——领域事件(Domain events) 基于DDD的现代ASP.NET开发框架--ABP系列之14.ABP领域层——领域事件(Domain events) ABP是“ASP.NET B ...

  6. 于 jsp第横梁list数据

            往往我们都会将查询到的数据显示到界面中,那么该怎样在界面显示.请看以下的具体解释:     0)前提得在jsp页面中获取后台传过来的数据(在此为List集合):             ...

  7. Codeforces Round #266 (Div. 2)-C,D

    C - Number of Ways 直接暴力从前往后寻找.假设找到1/3sum的位置,那么标记++.找到2/3的位置,总数加上标记数. #include<stdio.h> #includ ...

  8. Loadrunner11.00破解方法

    1.下载 从http://www.jb51.net/softs/71240.html上面下载到loadrunner 11.0 2.安装loadrunner 11.0 下载之后,我是直接解压到硬盘,再安 ...

  9. hdu 统计难题(map)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1251 map的强大之处,但是运行时间太长. 代码: #include <stdio.h> ...

  10. C#关于HttpClient的应用(二):极光推送IM集成

    public class JPushClient:BaseHttpClient { private String appKey; private String masterSecret; public ...