Angular JS (Angular.JS) 是一组用来开发Web页面的框架、模板以及数据绑定和丰富UI组件。它支持整个开发进程,提供web应用的架构,无需进行手工DOM操作。 AngularJS非常小,仅仅有60K,兼容主流浏览器。与 jQuery 配合良好。双向数据绑定可能是AngularJS最酷最有用的特性,将MVC的原理展现地淋漓尽致.

AngularJS的工作原理是:HTML模板将会被浏览器解析到DOM中, DOM结构成为AngularJS编译器的输入。

AngularJS将会遍历DOM模板, 来生成对应的NG指令,全部的指令都负责针对view(即HTML中的ng-model)来设置数据绑定。因此, NG框架是在DOM载入完毕之后, 才開始起作用的.

简单的使用例如以下:

在html中:

<body ng-app="ngApp">
<div ng-controller="ngCtl">
<label ng-model="myLabel"></label>
<input type="text" ng-model="myInput" />
<button ng-model="myButton" ng-click="btnClicked"></button>
</div>
</body>

在js中:

// angular app
var app = angular.module("ngApp", [], function(){
console.log("ng-app : ngApp");
}); // angular controller
app.controller("ngCtl", [ '$scope', function($scope){
console.log("ng-controller : ngCtl");
$scope.myLabel = "text for label";
$scope.myInput = "text for input"; $scope.btnClicked = function() {
console.log("Label is " + $scope.myLabel);
}
}]);

如上,我们在html中先定义一个angular的app,指定一个angular的controller,则该controller会相应于一个作用域(能够用$scope前缀来指定作用域中的属性和方法等). 则在该ngCtl的作用域内的HTML标签, 其值或者操作都能够通过$scope的方式跟js中的属性和方法进行绑定.

这样, 就实现了NG的双向数据绑定: 即HTML中呈现的view与AngularJS中的数据是一致的. 改动其一, 则相应的还有一端也会相应地发生变化.

这种方式,使用起来真的很方便. 我们仅关心HTML标签的样式, 及其相应在js中angular controller作用域下绑定的属性和方法. 仅此而已, 将众多复杂的DOM操作全都省略掉了.

这种思想,事实上跟jQuery的DOM查询和操作是全然不一样的, 因此也有非常多人建议用AngularJS的时候,不要混合使用jQuery. 当然, 二者各有优劣, 使用哪个就要看自己的选择了.

NG中的app相当于一个模块module, 在每一个app中能够定义多个controller, 每一个controller都会有各自的作用域空间,不会相互干扰.

看下边这段html:

<div ng-app="dataApp">
单位价格: <input type="number" min=0 ng-model="price" ng-init="price = 299"><br>
数量: <input type="number" min=0 ng-model="quantity" ng-init="quantity = 1"><br>
总价: {{ quantity * price }}
</div>

你会惊喜地发现, 甚至不用写一行的JS代码, 就可以完毕计算并在界面展示结果.

即: 在前端html中使用{{ }}括起来的变量, 是跟AngularJS中相应的controller作用域内的属性绑定在一起的. 实际上,{{}}等同于ng-bind指令, 即ng-bind="myData"就能将NG中的myData数据跟前端相应元素绑定在一起.这种话, 能够很方便地做到从NG中获取随意数据并实时展示在页面上了.

另外, $scope对象还提供了一个$apply方法, 用于进行html页面上的更新, 使用方式为:

$scope.$apply(function(){
$scope.myValue = "NewValue";
});

$scope对象, 我们能够理解为NG框架中的一个作用域对象, 在该作用域内能够做到数据和视图的相互绑定, 同一时候又能与其它$scope对象的作用域隔离开来.

当然, $scope也能够实现继承, 这部分内容在以后接触NG框架中其它对象的时候再分别做记录.

最新文章

  1. css图片精灵
  2. SSRS 2008 R2 错误:Timeout expired. The timeout period
  3. Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener org.springframework.beans.factory.BeanCreationException:
  4. Attribute和自定义Property
  5. Css Study - 横向MENU
  6. java 从args[]中赋值和程序直接赋值不一样?
  7. A trip through the Graphics Pipeline 2011_03
  8. C# 常用的dialogresult reset 以及if else 等检查获取客户操作信息的操作方法
  9. poj 3710 Christmas Game 博弈论
  10. c#字符串及数组操作
  11. 查看SQLServer数据库信息的SQL语句
  12. Android开发Thread+Handler演示样本(打地鼠)
  13. w5cValidator【AngularJS】 2.0 版本发布
  14. Java NIO 之 Buffer
  15. 使用Dockerfile创建一个tomcat镜像,并运行一个简单war包
  16. Kubernetes之存储
  17. SqlBulkCopy 批量插入
  18. js 浏览器 宽高 各种
  19. python常见循环练习
  20. μC/OS-II在Microblaze上的移植与使用专题--“安富利杯”赛灵思FPGA设计技巧与应用创新博文大赛参赛作品

热门文章

  1. $.extend(object) 和 $.fn.extend(object)
  2. 全面解析Vue.nextTick实现原理
  3. 索尼(SONY) SVE1512S7C 把WIN8降成WIN7图文教程
  4. CCCC L1-002. 打印沙漏【图形打印】
  5. 网络扫描集成工具SPARTA
  6. Loj #6287 诗歌
  7. Maven 多模块父子工程 (含Spring Boot示例)
  8. Java NIO.2 Files类的常用方法
  9. apache url rewrite问题
  10. iptables 一些有用的规则