首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

2、Angular JS 学习笔记 – 双向数据绑定和Scope概念

在模板linking阶段,指令配置watch表达式在作用域中;watch允许指令通知属性的变化,也允许指令渲染更新后的值到dom。 控制器和指令都有作用域的引用,但并不是彼此引用。...如果watch修改了模型中的值,将会触发一次 Creation / 创建 根作用域在应用启动的时候由$injector创建,在template linking阶段和指令时将会创建新的子作用域; Watcher...作用域和控制器: 作用域和控制器在下面的情况下相互作用: 控制器使用作用域暴露方法给模板 控制器定义方法可以改变模型 控制器可以注册监视器到模型,在控制器的行为执行后立即执行。...查看ng-controller了解更多信息 作用域$watch性能考虑 作用域脏检查属性变动在angular中是一个常规的操作,所以脏检查函数需要尽可能的快。...一个显式的调用只有在实现自定义事件的会调用使用,或在工作在第三方的库的回调中。 进入Angular执行上下文通过调用scope.

13.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    7-进军 angular1.x 表单和事件、模块

    现在你可以在 AngularJS 应用中添加控制器,指令,过滤器等。...}; }); script> 复制代码 模块和控制器包含在 JS 文件中 通常 AngularJS 应用程序将模块和控制器包含在 JavaScript 文件中。...在以下实例中, "myApp.js" 包含了应用模块的定义程序, "myCtrl.js" 文件包含了控制器: AngularJS 实例 <script src="http://apps.bdimg.com...$error 表单的验证错误 控制器的意义:控制器是分发者,处理临时数据、对域($scope)进行划分 指令的意义:可以重复使用,可自定义创建,如代码中compare 表单验证的意义:数据真实性、可靠性的保证...使用对象和注意 form 表单的 name 属性 注意 required 的使用 $scope 是一个作用域,注意使用范围 完善的 MVC 模型我们要把几个曾侧分开

    2.3K20

    Angular企业级开发(7)-MVC之控制器

    2.理解控制器 在AngularJS的控制器中,构造函数会有$scope参数。...3.控制器的作用 3.1 在控制器中初始化模型(添加属性) 创建控制器并将它附加到DOM元素之后,AngularJS会创建一个子作用域。子作用域保存着对应控制器的数据模型。...控制器并列Demo 4.2 视图中控制器嵌套 默认情况下,AngularJS在当前作用域中无法找到某个属性,就会在父级作用域中进行查找。即子级控制器会继承父级控制器中的对象。...但是子级作用域和父级作用域中有相同的属性,子级使用自己的作用域。这个时候子级作用域要访问父级作用域的属性可以通过$parent。类似JavaScript本身的原型链方式。...在控制器并行和嵌套的demo中,视图上我们都使用花括号包含着name,userName等属性。

    1.9K50

    3、Angular JS 学习笔记 – Controllers

    理解控制器 在Angular中,一个控制器是一个javascript构造函数用于填充Angular作用域。...一个新的子作用域将可以作为一个参数$scope被注入到控制器构造函数。 控制器用于: 配置作用域对象的初始化状态 添加行为到作用域对象 不要将控制器用于: 维护DOM – 控制器应该只包含业务逻辑。...格式化输入 – 应该使用angular表单控制器处理 过滤输出 – 应该使用angular过滤器处理 在多个控制器中共享代码或状态 – 应该使用angular service。...建立作用域对象的初始化状态 通常,当你创建一个应用你必须设置Angular作用域的初始化状态。你通过附加属性到$scope对象去设置作用域初始化状态。这些属性包括视图模型(这个模型将通过视图呈现)。...作用域中的所有属性都将提供给在dom中注册了控制器的模板。 下面的例子演示了创建一个GreetingController,附加一个包含字符串’Hola!’的属性到作用域上。

    2.5K20

    AngularJS入门心得4——漫谈指令scope

    指令的内部可以访问外部指令的作用域,并且模板也可以访问外部的作用域对象。为了将作用域传递进去,scope参数的值必须通过{}或true设置成隔离作用域。...如果没有设置scope参数,那么指令内部的作用域将被设置为传入模板的作用域。        ...同时,{{name}}能够读取到指令外的作用域,即控制器中scope.name的值。   有了上面的铺垫,我们就可以来介绍今天的主题了,先上菜   index.html: 作用域,表示是共享作用域。...即指令直接共享外部控制器的scope,此时directive中的scope就和控制器紧密相关,所以此时,scope.name在指令的link中被重新赋值,这时候控制器和指令中的name都被更新为Jeff

    1.9K60

    angularjs 控制器、作用域、广播详解

    在使用控制器时要注意几点: 1.不要去复用controller,一个控制器一般只负责一小块视图;(一般控制器处理的都是业务逻辑,业务逻辑的复用性一般很小) 2.不要在controller中操作DOM,这不是控制器的职责...,在$rootScope上附加太多业务逻辑并不是好主意,这与污染javaScript的全局作用域是一样的) 7....$scope也是实现双向数据绑定的基础; 8.可以用angular.element($0).scope()来进行调试; 9.$scope可以在控制器之间传播事件,可以向上$scope....,但作用域是有层次的,所以我们可以在作用域上通过广播来传递事件。...Angularjs中不同作用域之间可以通过组合使用$emit,$broadcast,,$on的事件广播机制来进行通信 $emit的作用是将事件从子级作用域传播至父级作用域,包括自己,直至根作用域。

    1.9K51

    Angularjs基础(一)

    ng-app指令                ng-app 指令标记了AngularJS 脚本的作用域,在都是AngularJS...脚本作用域,开发者也在         局部使用ng-app 指令,如,则AngurJS 脚本仅在该中运行。     ...模型和控制器     在PhoneListCtrl 控制器里面初始化了数据模型(这里只不过是一个包含了数组的函数,数组中存储的对象是手机数据列表)         function PhoneListCtrl...手机的数据此时与注入到我们控制器函数的作用域($scope)相关联。当应用启动之后,会有一个跟作用域创建出来,       而控制器的作用域的一个典型后继。...这个控制器的作用域对所有的标记内部的       数据绑定有效。

    3.1K100

    Angularjs基础(三)

    根作用域     所有的应用都有一个$rootScope,它可以作用在ng-app 指令包含的所有HTML 元素中。     ...$rootScope可作用域整个应用中,是各个controller中scope的桥梁。用rootscope定义的值,可以在各个controller中使用。     ...在AngularJS 使用$scope是一个应用像(属于应用变量和函数)           控制器的$scope(相当于作用域,控制范围)用来保存AngularJS Mode(模型)的对象。           ...控制器在作用域中创建两个属性(firstName 和lastName)。           ng-model 指令绑定输入域到控制器的属性(firstName 和lastName)。...    在大型的应用程序中,通常是把控制器存储在外部文件中。

    3.1K50

    AngularJS Scope(作用域)

    Scope(作用域) 是应用在 HTML (视图) 和 JavaScript (控制器)之间的纽带。 Scope 是一个对象,有可用的方法和属性。 Scope 可应用在视图和控制器上。...---- 如何使用 Scope 当你在 AngularJS 创建控制器时,你可以将 $scope 对象当作一个参数传递: AngularJS 实例 控制器中的属性对应了视图上的属性: 在视图和控制器中使用。...在以上两个实例中,只有一个作用域 scope,所以处理起来比较简单,但在大型项目中, HTML DOM 中有多个作用域,这时你就需要知道你使用的 scope 对应的作用域是哪一个。...---- 根作用域 所有的应用都有一个 $rootScope,它可以作用在 ng-app 指令包含的所有 HTML 元素中。 $rootScope 可作用于整个应用中。

    1.5K20

    Angular源码分析之$compile

    @(Angular) $compile,在Angular中即“编译”服务,它涉及到Angular应用的“编译”和“链接”两个阶段,根据从DOM树遍历Angular的根节点(ng-app)和已构造完毕的...随后,在返回的compositeLinkFn中,则是遍历linkFns,针对每个链接函数,创建起对应的作用域对象(针对创建隔离作用域的指令,创建隔离作用域对象,并保存在节点的缓存中),并处理指令是否设置了...在返回的nodeLinkFn中,根据用户指令的定义,如果指令带有隔离作用域,则创建一个隔离作用域,并在当前的dom节点上绑定ng-isolate-scope类名,同时将隔离作用域缓存到dom节点上; 接下来...,完成隔离作用域属性的单向绑定(@),双向绑定(=)和函数的引用(&),针对隔离作用域的双向绑定模式(=)的实现,则是通过自定义的编译器完成简单Angular语法的编译,在指定作用域下获取表达式(标示符...在publicLinkFn中,完成根节点与根作用域的绑定,并在根节点缓存指令的控制器实例,最终执行合成链接函数,完成了Angular最重要的编译,链接两个阶段,从而开始了真正意义上的双向绑定。

    1.5K50

    angularjs学习第一天笔记

    angular.module('myApp', []);   5、作用域     angular作用域是其最主要核心特征之一,通过$scope来表示。...作用如下:       a.应用的作用域是和应用的数据模型相关联的       b.同时作用域也是表达式执行的上下文。       c....$scope 对象是定义应用业务逻辑、控制器方法和视图属性的地方。       d.作用域是视图和控制器之间的胶水       e....  控制器的关键词为ng-controller,其作用还是讲页面逻辑根据功能模块分割中更小模块。     ...控制器是可以嵌套的,作用域也是嵌套的     定义使用方式如下:     var app = angular.module('模块名称', []);     app.controller('控制器名称'

    2.2K10

    5-进军 angular1.x 服务

    angular1.x 学习目录 1-angular 学习导航和基础 2-表达式和指令,数据绑定 3-模型和作用域 scope 4-控制器和过滤器 5-service 服务 service 服务 angular...在 AngularJS 中,服务是一个函数或对象,可在你的 AngularJS 应用中使用。 AngularJS 内建了30 多个服务。...由于 angular 的局限性 angular 需要实时的监控 在很多服务中,比如 $location 服务,它可以使用 DOM 中存在的对象,类似 window.location 对象,但 window.location...this.myFunc = function (x) { return x.toString(16); } }); 复制代码 创建一个 名为 hexafy 的服务 这样去使用 在控制器中...全局函数注册:方法一 全局注册和控制器(作用域限制)注册 // 注册全局服务(即变量)myService 可以向其添加一些全局使用的函数 app.service('myService', [function

    96450

    前端MVC学习总结(二)——AngularJS验证、过滤器、指令

    语法格式如下: {{ express | filter:parameter1:p2:p3… | … | …}} 过滤器分了内置过滤器与自定义过滤器,过滤器的调用方式也分了在模板中调用与在函数中调用。...2.1.2、在脚本中调用过滤函数 在函数中调用过滤器的方法是:在控制中添加对$filter的依赖,$filter("过滤函数名称")(被过滤对象,'参数') 示例代码: angular支持基于“视图-模型-控制器”设计模式原则的主要方面。 Angular中的MVC组件有: 模型 — 模型是一个域的属性集合;域被附加到DOM上,通过绑定来存取域属性。...template:插入指令元素的模板       restrict:允许指令应用的范围       replace:告诉编译器用指令模板取代定义该指令的元素       transclude:是否可以访问内部作用域以外的作用域...      scope:指定内部作用域       link:链接函数       controller:定义控制器来管理指令作用域和视图       require:指定所需要的其它指令    };

    15.4K60

    angularjs学习第一天笔记

    angular.module('myApp', []);   5、作用域     angular作用域是其最主要核心特征之一,通过$scope来表示。...作用如下:       a.应用的作用域是和应用的数据模型相关联的       b.同时作用域也是表达式执行的上下文。       c....$scope 对象是定义应用业务逻辑、控制器方法和视图属性的地方。       d.作用域是视图和控制器之间的胶水       e....  控制器的关键词为ng-controller,其作用还是讲页面逻辑根据功能模块分割中更小模块。     ...控制器是可以嵌套的,作用域也是嵌套的     定义使用方式如下:     var app = angular.module('模块名称', []);     app.controller('控制器名称

    2.1K30

    达观数据对AngularJS技术的思考与实践

    二、Angular 的$scope,controller和数据双向绑定($apply(),$digest(),$watch): $scope 对象在 AngularJS 中充当数据模型的作用,也就是一般...当你想要创建一个可重用的组件时隔离作用域是一个很好的选择,通过隔离作用域我们确保指令是‘独立’的,并可以轻松地插入到任何HTML app中,并且这种做法防止了父作用域被污染。...一般用在控制器和工场方法中。 控制器中的依赖注入: ? 工厂方法:工场方法负责创建AngularJS中的大部分对象。比如指令,服务,过滤器。工厂方法一般在模块中使用。 ?...H1始终显示world,H2中会显示键入值。 ? H1,H2都显示键入值。 2)控制器的继承:子控制器的作用域将会原型继承父控制器的作用域。...因此当你需要重用来自父控制器中的功能时,你所要做的就是在父作用域中添加相应的方法。这样一来,自控制器将会通过它的作用域的原型来获取父作用域中的所有方法。 ?

    5.4K150

    AngularJS浅谈-博客

    6、注入器($injector)是用来创建“编译服务(\$compile service)”和“根作用域(\$rootScope)”的。...控制器的 $scope (相当于作用域、控制范围)用来保存AngularJS Model(模型)的对象。 控制器在作用域中创建了两个属性 (firstName 和 lastName)。...ng-model 指令绑定输入域到控制器的属性(firstName 和 lastName)。 记住一点:在大型的应用程序中,通常是把控制器存储在外部文件中。...用javascript定义作为视图控制器逻辑。在AngularJs作为MVC框架,在控制器中我们无需添加对于dom级的事件监听,这些在AngularJs中已经内置了。...那么它就不知道这里该加载什么模块,于是,它也不认识在模块中定义的textController控制器。

    2.4K30
    领券