刚开始接触时总是去wiki或各种百科以了解一番。
它们会告诉我一些MVVM、双向数据绑定、依赖注入等等名词,觉得这些名词好上档次,然后我很可能就不打算用这个东西了。

AngularJS是什么?

完全使用 JavaScript编写的客户端技术。同其他历史悠久的 Web技术( HTML、 CSS
和JavaScript)配合使用,使Web应用开发比以往更简单、更快捷。

不考虑那些名词,本篇帮助你快速了解AngularJS的基本用法。

感谢 @myqianlan 菊苣提醒,本文用的AngularJS版本为1.2.x,1.3.x中不再用本文中提到的方式声明controller。


先从这段开始:

  1. <div ng-app="" data-ng-init="name='Kavlez'">
  2. <p>Name: <input type="text" ng-model="name"></p>
  3. <p ng-bind="name"></p>
  4. {{name}}
  5. {{6+8}}
  6. </div>
  • ng-app:定义一个AngularJS应用,被其包含的内容都属于该应用。
  • ng-init:初始化应用数据。
  • ng-model:将数据绑定到当前应用。
  • ng-bind:将应用中定义的变量在该标签中显示

AngularJS的指令都是以ng开头,或者也可以使用data-ng开头。
AngularJS的表达式用两个大括号表示:{{expression}}
这便是AngularJS最基本的功能:数据绑定

我们可以对各种类型进行绑定并显示:

  • Number

    1. <div ng-app="" ng-init="quantity=1;cost=5">
    2. <p>Total : ¥{{ quantity * cost }}</p>
    3. </div>
  • String

    1. <div ng-app="" ng-init="firstName='Kavlez';lastName='Jin'">
    2. <p>The name is {{ firstName + " " + lastName }}</p>
    3. </div>
  • Object

    1. <div ng-app="" ng-init="person={firstName:'Kavlez',lastName:'Jin'}">
    2. <p>The name is {{ person.lastName }}</p>
    3. </div>
  • Array

    PS: 可以使用ng-repeat进行迭代

    1. <div ng-app="" ng-init="myArr=[0,2,4,6,8]">
    2. <p ng-repeat="element in myArr">
    3. {{ element }}
    4. </p>
    5. </div>

Controllers

我们用controller对一个AngularJS应用进行控制。
ng-controller定义一个controller,声明所有被它包含的元素都属于这个控制器。

例如:

  1. <div ng-app="" ng-controller="personController">
  2. <h1>{{ person.name +' is a(an) '+person.job }}</h1>
  3. <h1>{{ person.sayHi() }}</h1>
  4. </div>
  5. <script>
  6. function personController($scope) {
  7. $scope.person = [];
  8. $scope.person.name='Kavlez'
  9. $scope.person.job='brogrammer'
  10. $scope.person.sayHi = function(){
  11. return "Hi! I'm "+ $scope.person.name + ", I'm a(an) " + $scope.person.job;
  12. }
  13. }
  14. </script>

当然,我们应该使用更高效的组织方式。
AngularJS支持将Controller定义在其他js文件中,比如上面的例子可以改为:

  1. <div ng-app="" ng-controller="personController">
  2. <h1>{{ person.name +' is a(an) '+person.job }}</h1>
  3. </div>
  4. <script type="text/javascript" src="js/app.js"></script>

Module

到目前为止,定义一个Angular app都用ng-app=""的方式。
可行,但是这个app下的变量和函数都是global的,而且会造成controller污染(pollute)。
而通常,我们用module把app组织起来。
我们可以通过ng-app="名称"angular.modele()来声明一个module。
该方法有两个参数:

  1. 模块的名称
  2. 依赖列表

比如,之前的例子可以改为:

  1. <div ng-app="myApp" ng-controller="fighterController">
  2. <script>
  3. var myApp = angular.module("myApp",[]);
  4. myApp.controller("fighterController", function($scope) {
  5. //..
  6. }
  7. </script>
  8. </div>

如果将app和controller放到两个文件分别定义,则:

  1. <div ng-app="myApp" ng-controller="fighterController">
  2. <script src="myApp.js"></script>
  3. <script src="myAppControllers.js"></script>
  4. </div>

myApp.js:

  1. var myApp = angular.module("myApp",[]);

myAppControllers.js:

  1. myApp.controller("fighterController", function($scope) {
  2. //..
  3. }

Filter

这个东西可以加在表达式里面,改变表达式的输出格式。
我们可以用以下Filters:

Filter Description
uppercase 转大写
lowercase 转小写
currency 转货币格式
orderBy 按指定属性排序
filter 按指定关键字进行过滤

前3种可以直接用在表达式中,比如:

  1. {{name | uppercase}}
  2. {{name | lowercase}}
  3. {{total | currency}}

filter和orderBy通常用于数组:

  1. <div ng-app="" ng-controller="fighterController">
  2. <input ng-model="search"/>
  3. <ul>
  4. <li ng-repeat="f in fighters|filter:search">
  5. {{ f }}
  6. </li>
  7. </ul>
  8. <script>
  9. function fighterController($scope) {
  10. $scope.fighters = [
  11. {name:'Ryu',country:'Japan'},
  12. {name:'Ken',country:'USA'},
  13. {name:'Chun Li',country:'China'},
  14. {name:'GuiLe',country:'USA'},
  15. {name:'Zangief',country:'Russia'}
  16. ];
  17. }
  18. </script>
  19. </div>

当然,数据不会这样放在一个controller里。
我们可以通过$http来请求数据并进行绑定。
上面的例子可以改为:

  1. function fighterController($scope,$http) {
  2. var url = '请求地址';
  3. $http.get(url).success(function(response) {
  4. $scope.fighters = response;
  5. })
  6. }

AngularJS - 快速入门的更多相关文章

  1. AngularJS快速入门指南20:快速参考

    thead>tr>th, table.reference>tbody>tr>th, table.reference>tfoot>tr>th, table ...

  2. AngularJS快速入门指南19:示例代码

    本文给出的大部分示例都可以直接运行,通过点击运行按钮来查看结果,同时支持在线编辑代码. <div ng-app=""> <p>Name: <input ...

  3. AngularJS快速入门指南18:Application

    是时候创建一个真正的AngularJS单页面应用程序了(SPA). 一个AngularJS应用程序示例 你已经了解了足够多的内容来创建第一个AngularJS应用程序: My Note Save Cl ...

  4. AngularJS快速入门指南17:Includes

    使用AngularJS,你可以在HTML中包含其它的HTML文件. 在HTML中包含其它HTML文件? 当前的HTML文档还不支持该功能.不过W3C建议在后续的HTML版本中增加HTML import ...

  5. AngularJS快速入门指南16:Bootstrap

    thead>tr>th, table.reference>tbody>tr>th, table.reference>tfoot>tr>th, table ...

  6. AngularJS快速入门指南15:API

    thead>tr>th, table.reference>tbody>tr>th, table.reference>tfoot>tr>th, table ...

  7. AngularJS快速入门指南14:数据验证

    thead>tr>th, table.reference>tbody>tr>th, table.reference>tfoot>tr>th, table ...

  8. AngularJS快速入门指南13:表单

    一个AngularJS表单是一组输入型控件的集合. HTML控件 HTML输入型标签标包括: input标签 select标签 button标签 textarea标签 HTML表单 HTML表单将各种 ...

  9. AngularJS快速入门指南12:模块

    AngularJS模块定义了一个application. 模块是一个application中不同部分的容器. application中的所有控制器都应该属于一个模块. 带有一个控制器的模块 下面这个a ...

  10. AngularJS快速入门指南11:事件

    AngularJS拥有自己的HTML事件指令. ng-click指令 ng-click指令定义了AngularJS的click事件. <div ng-app="" ng-co ...

随机推荐

  1. 终于完成了Josephus的C语言实现啦~~

    /*以下程序用来解决Josephus问题,现在只是完成了M>N的情况,2015-08-20 22:22:20*//*发现一个问题:数组的赋值问题:char People[N]={1};并不代表所 ...

  2. CentOS 7 安装Redis 2.8.7

    1.下载软件: wget wget http://download.redis.io/releases/redis-2.8.7.tar.gz 2.解压软件并编译安装: tar -zxvf redis- ...

  3. 怎样对ZBrush中的材料进行渲染和着色

    ZBrush可以实时的进行不断的渲染和着色. 对于绘制操作,ZBrush®增加了新的范围尺度,可以让你给基于像素的作品增加深度,材质,光照和复杂精密的渲染特效,真正实现了 2D 与 3D 的结合,模糊 ...

  4. 好玩的-记最近玩的几个经典ipad ios游戏

    最近回了趟家,在家里闲着没事去app store找了找一些高分游戏玩一玩,下面就是我最近玩的游戏. 海岛奇兵 想必大家都很了解,这是由开发过clash of clan部落冲突的公司所开发的另一款多人策 ...

  5. UESTC 31 饭卡(Card) --背包问题

    背包问题. 思路:如果m<5,此时也不能消费,所以此时答案为m m>=5: 求出背包容量为m-5,买前n-1样便宜的菜(排个序)的最大价值(即最大消费,即消费完后剩余值最接近5)最后减去最 ...

  6. HDU 1671 Phone List

    一道字典树的模板题,每次插入前查询是否有该串的某个前缀子串存在,或者该串是否某个串的前缀.具体实现是在插入时串的结尾做一个标记,如果某一个串在查询的时候找到一个标记,说明存在前缀:第二种情况是这个串遍 ...

  7. 【从0到1】android网络框架的选型参考

    项目会使用到 socket tcp 级的网络访问,想选取一个使用较成熟异步网络框架, 提到的网络框架: 1. volley, 2. xutils. 3. android 4. netty, 5. mi ...

  8. Android 距离传感器修复 修复打电话黑屏 无法快速唤醒屏幕的BUG

    接触Android Xposed开发也很久了,学了这么久的Java,也该弄点东西出来了, public ProximitySensor(Context paramContext, AudioModeP ...

  9. 后台首页品字形(frameset)框架搭建

    get_defined_constants([true])//显示所有常量信息.参数true,表示分组显示,查看当前系统给我提供了哪些常量可以使用,包括自定义常量. __CONTROLLER__//获 ...

  10. 13SpringMvc_限定某个业务控制方法,只允许GET或POST请求方式访问

    这篇文章要实现的功能是:在一个Action中,有些业务方法只能是post提交上来的才能执行,有些方法是只能get提交上来的才能执行. 比如上篇文章中的UserAction.java(代码如下) pac ...