AngularJS (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框架中其他对象的时候再分别做记录.

AngularJS入门(1)-双向数据绑定的更多相关文章

  1. Swift3.0 中 Strings/Characters 闲聊

    Swift中String类型,说白了就是Character类型实例的集合,在开发过程中,我们一般采用两种方式来求字符串的长度,第一种是转成Objective-C中的Nsstring类型,通过length方法来获取其长度,第二种是通过字符串属性characters.count的方式获得。

  2. 详解使用angularjs的ng-options时如何设置默认值(初始值)

    本篇文章主要介绍了详解使用angularjs的ng-options时如何设置默认值(初始值),具有一定的参考价值,有兴趣的可以了解一下

  3. Angular使用ng-messages与PHP进行表单数据验证

    这篇文章主要介绍了Angular使用ng-messages与PHP进行表单数据验证,ng-messages提供了更方便的表单数据验证服务,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  4. Angular中ng-options下拉数据默认值的设定方法

    本篇文章主要介绍了Angular中ng-options下拉数据默认值的设定方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. angularJs的ng-class切换class

    这篇文章主要介绍了angularJs的ng-class切换class,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  6. 不用GD库生成当前时间的PNG格式图象的程序

    该程序是不用GD库可以生成当前时间的PNG格式图象,给人大开眼界,很有参考价值.teaman整理

  7. AngularJS监听ng-repeat渲染完成的方法

    这篇文章主要介绍了AngularJS监听ng-repeat渲染完成的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  8. Angular中使用ng-zorro图标库部分图标不能正常显示问题

    这篇文章主要介绍了Angular中使用ng-zorro图标库部分图标不能正常显示问题,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  9. Angular2学习教程之ng中变更检测问题详解

    这篇文章主要给大家介绍了Angular2学习教程之ng中变更检测问题的相关资料,文中介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。

  10. 深究AngularJS——ng-checked(回写:带真实案例代码)

    本篇文章主要介绍了深究AngularJS——ng-checked(回写:带真实案例代码),具有一定的参考价值,感兴趣的小伙伴们可以参考一下

随机推荐

  1. Angular2 innerHtml删除样式

    我正在使用innerHtml并在我的cms中设置html,响应似乎没问题,如果我这样打印:{{poi.content}}它给了我正确的内容:``但是当我使用[innerHtml]=“poi.content”时,它会给我这个html:当我使用[innerHtml]时,有谁知道为什么它会剥离我的样式Angular2清理动态添加的HTML,样式,……

  2. 为Angular根组件/模块指定@Input()参数

    我有3个根组件,由根AppModule引导.你如何为其中一个组件指定@input()参数?也不由AppModalComponent获取:它是未定义的.据我所知,你不能将@input()传递给bootstraped组件.但您可以使用其他方法来做到这一点–将值作为属性传递.index.html:app.component.ts:

  3. angular-ui-bootstrap – 如何为angular ui-bootstrap tabs指令指定href参数

    我正在使用角度ui-bootstrap库,但我不知道如何为每个选项卡指定自定义href.在角度ui-bootstrap文档中,指定了一个可选参数select(),但我不知道如何使用它来自定义每个选项卡的链接另一种重新定义问题的方法是如何使用带有角度ui-bootstrap选项卡的路由我希望现在还不算太晚,但我今天遇到了同样的问题.你可以通过以下方式实现:1)在控制器中定义选项卡href:2)声明一个函数来改变控制器中的散列:3)使用以下标记:我不确定这是否是最好的方法,我很乐意听取别人的意见.

  4. 离子框架 – 标签内部的ng-click不起作用

    >为什么标签标签内的按钮不起作用?>但是标签外的按钮(登陆)工作正常,为什么?>请帮我解决这个问题.我需要在点击时做出回复按钮workingdemo解决方案就是不要为物品使用标签.而只是使用divHTML

  5. Angular 2:将值传递给路由数据解析

    我正在尝试编写一个DataResolver服务,允许Angular2路由器在初始化组件之前预加载数据.解析器需要调用不同的API端点来获取适合于正在加载的路由的数据.我正在构建一个通用解析器,而不是为我的许多组件中的每个组件设置一个解析器.因此,我想在路由定义中传递指向正确端点的自定义输入.例如,考虑以下路线:app.routes.ts在第一个实例中,解析器需要调用/path/to/resourc

  6. angularjs – 解释ngModel管道,解析器,格式化程序,viewChangeListeners和$watchers的顺序

    换句话说:如果在模型更新之前触发了“ng-change”,我可以理解,但是我很难理解在更新模型之后以及在完成填充更改之前触发函数绑定属性.如果您读到这里:祝贺并感谢您的耐心等待!

  7. 角度5模板形式检测形式有效性状态的变化

    为了拥有一个可以监听其包含的表单的有效性状态的变化的组件并执行某些组件的方法,是reactiveforms的方法吗?

  8. Angular 2 CSV文件下载

    我在springboot应用程序中有我的后端,从那里我返回一个.csv文件WheniamhittingtheURLinbrowsercsvfileisgettingdownloaded.现在我试图从我的角度2应用程序中点击此URL,代码是这样的:零件:服务:我正在下载文件,但它像ActuallyitshouldbeBook.csv请指导我缺少的东西.有一种解决方法,但您需要创建一个页面上的元

  9. angularjs – Angular UI-Grid:过滤后如何获取总项数

    提前致谢:)你应该避免使用jQuery并与API进行交互.首先需要在网格创建事件中保存对API的引用.您应该已经知道总行数.您可以使用以下命令获取可见/已过滤行数:要么您可以使用以下命令获取所选行的数量:

  10. angularjs – 迁移gulp进程以包含typescript

    或者我应该使用tsc作为我的主要构建工具,让它解决依赖关系,创建映射文件并制作捆绑包?

返回
顶部