好好爱自己!

angular directive 的controllerAs的用法

原文: https://stackoverflow.com/questions/31857735/using-controlleras-with-a-directive

-------------------------------------------------------------------------------------

With "controllerAs", the controller instance alias - vm, in your case - is published on the scope as the .vm property of the scope.

So, to access its properties (i.e. the properties of the controller), you need to specify {{vm.text}} or ng-click="vm.click".

 

When you use controllerAs syntax, then you have to use

bindToController: true

it will work in your directive.

 

When using 'controllerAs' syntax ,as above,the scope is bound to the controller’s 'this' reference. So it allows us to introduce a new namespace('vm' here) bound to our controller without the need to put scope properties in an additional object literal(say $scope). So accessing anything in controller's scope,requires 'vm' namespace, as,

'<button ng-click="click">{{vm.text}}</button>'

下面是另外一种风格的directive的写法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<!DOCTYPE html>
<html ng-app="app">
 
  <head>
    <script data-require="angular.js@1.4.3" data-semver="1.4.3" src="https://code.angularjs.org/1.4.3/angular.js"></script>
    <link rel="stylesheet" href="style.css" />
    <script src="script.js"></script>
  </head>
 
  <body>
    <h1>Hello Plunker!</h1>
    <test></test>
  </body>
 
</html>

  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
angular
    .module('app', []);
 
angular
    .module('app')
    .directive('test', test);
 
function test() {
    return {
        restrict: 'E',
        template: '<button ng-click="vm.click()">{{vm.text}}</button>',
        controller: testCtrlaaa,
        controllerAs: 'vm'
    }
}
// 下面的这三行可以不要的。
//angular
//    .module('app')
//    .controller('testCtrlttttada', testCtrlaaa);
 
function testCtrlaaa() {
  var vm = this;
  vm.text = "TEST";
  vm.click= function(){
    alert('aaaa');
  }
}

  


















posted @   立志做一个好的程序员  阅读(230)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
历史上的今天:
2017-06-29 golang time.Duration()的问题解疑
2016-06-29 php 中的全局变量的理解

不断学习创作,与自己快乐相处

点击右上角即可分享
微信分享提示