详解angularjs中的隔离作用域理解以及绑定策略

我们首先看下面的例子:

rush:xhtml;"> <Meta charset="utf-8">

我们在看看IsolateScope中的代码

rush:js;"> var myModule = angular.module("MyModule",[]); myModule.directive("hello",function() { return { restrict: 'AE',template: '
',replace: true } });

这时候当运行页面的时候发现只要有一个input中的输入变化了,这时候所有的nput的内容都会变化:

这样就会面临一个问题:我们的指令无法单独使用,于是就有了独立作用域的概念。

rush:js;"> var myModule = angular.module("MyModule",scope:{},replace: true } });

通过把scope设置为{},那么每一个指令就具有自己独立的scope空间,于是就不会相互影响了。但是angularjs中最重要的概念是:绑定策略。其具有绑定策略如下:

第一步:

我们看看原始的方式,也就是不使用上面的三种绑定方式

rush:xhtml;"> <Meta charset="utf-8">

看看ScopeAt中的内容

rush:js;"> var myModule = angular.module("MyModule",[]); myModule.controller('MyCtrl',['$scope',function($scope){ $scope.ctrlFlavor="百威"; //在控制器中$scope中设置了ctrlFlavor属性 }]) //定义了drink指令 myModule.directive("drink",function() { return { restrict:'AE',template:"
{{flavor}}
",link:function(scope,element,attrs){ scope.flavor=attrs.flavor; //链接的时候把drink指令上的flavor属性放在scope中,然后在template中显示 } } });

这时候的DOM结构如下:

但是,这种方式要通过attrs.flavor来获取这个指令的属性值,然后需要把这个属性值绑定到scope对象上,最后在template中才能通过{{}}这种形式获取到scope中的值!

第二步:

我们使用上面的@来替换第一种方式,因为它每次都需要自己指定link函数

rush:js;"> var myModule = angular.module("MyModule",scope:{ flavor:'@' },template:"
{{flavor}}
" } });

这种方式就是把指令drink中的flavor属性值绑定到scope对象上,而且这是ng为我们自动绑定的。不过,@绑定绑定的是字符串,而不是对象!

第三步:

我们来学习一下双向数据绑定

rush:xhtml;"> <Meta charset="utf-8">
Directive:

我们再来看看控制器中内容

rush:js;"> var myModule = angular.module("MyModule",[]); //指定了控制器对象 myModule.controller('MyCtrl',function($scope){ $scope.ctrlFlavor="百威"; }]) //指定了指令 myModule.directive("drink",scope:{ flavor:'=' //这里通过'='指定了drink指令的flavor和scope中的双向数据绑定! },template:'

这就是'='这种绑定方式。其实现了双向的数据绑定策略。我们看看最后的DOM结构是怎么样的:

其实双向数据绑定是很明显的,需要好好理解双向数据绑定(指令和控制器之间的双向数据绑定)

第四步:

我们使用&绑定策略来完成对controller父级方法调用

rush:xhtml;"> <Meta charset="utf-8">

其中定义了三个指令greeting,每一个指令都需要调用controller中的一个sayHello方法,(指出了可以通过定义属性的方式使得控制器和指令之间进行交互,不过这里我们可以通过简单的&完成同样的功能)并且传入不同的参数name值:

rush:js;"> var myModule = angular.module("MyModule",[]); //为控制器指定了一个sayHello方法,同时为这个方法可以传入一个参数 myModule.controller('MyCtrl',function($scope){ $scope.sayHello=function(name){ alert("Hello "+name); } }]) myModule.directive("greeting",scope:{ greet:'&'//传递一个来自父scope的函数用于稍后调用获取greet参数,得到sayHello(name)函数 },//在template中我们在ng-click中指定一个参数,其指定方式为调用controller中greet方法,传入的参数name值为username //也就是ng-model='userName'中指定的参数 template:'
'+ '

通过&就可以完成对父级作用方法调用,而不是采用传统的通过为指令指定属性的方式完成控制器和指令之间的通行!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...