惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Application and Cybersecurity Blog
Application and Cybersecurity Blog
S
Securelist
K
Kaspersky official blog
Scott Helme
Scott Helme
C
CXSECURITY Database RSS Feed - CXSecurity.com
GbyAI
GbyAI
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
C
Cisco Blogs
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
博客园 - Franky
Security Latest
Security Latest
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Y
Y Combinator Blog
T
Threat Research - Cisco Blogs
L
LINUX DO - 热门话题
C
Cyber Attacks, Cyber Crime and Cyber Security
Project Zero
Project Zero
Cisco Talos Blog
Cisco Talos Blog
月光博客
月光博客
I
Intezer
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
人人都是产品经理
人人都是产品经理
L
Lohrmann on Cybersecurity
Recorded Future
Recorded Future
Latest news
Latest news
V2EX - 技术
V2EX - 技术
T
The Exploit Database - CXSecurity.com
H
Heimdal Security Blog
F
Fortinet All Blogs
Cloudbric
Cloudbric
IT之家
IT之家
博客园 - 叶小钗
Microsoft Security Blog
Microsoft Security Blog
P
Proofpoint News Feed
博客园 - 司徒正美
Apple Machine Learning Research
Apple Machine Learning Research
PCI Perspectives
PCI Perspectives
AWS News Blog
AWS News Blog
H
Help Net Security
S
Security @ Cisco Blogs
酷 壳 – CoolShell
酷 壳 – CoolShell
Recent Announcements
Recent Announcements
Hacker News - Newest:
Hacker News - Newest: "LLM"
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
F
Full Disclosure
S
Schneier on Security
S
Security Affairs
T
Tenable Blog

博客园 - 开发手游啦啦啦

用TypeScript开发爬虫程序 ABP导航源码分析 ABP的语言切换 AngularJs自定义指令详解(10) - 执行次序 AngularJs自定义指令详解(9) - terminal AngularJs自定义指令详解(8) - priority AngularJs自定义指令详解(7) - multiElement AngularJs自定义指令详解(5) - link AngularJs自定义指令详解(4) - transclude AngularJs自定义指令详解(3) - scope AngularJs自定义指令详解(2) - template AngularJs自定义指令详解(1) - restrict ABP的Zero Sample ABP的工作单元 ABP的数据过滤器(Data Filters) ABP的事件总线和领域事件(EventBus & Domain Events) 初入Cocos2d-x 2.2 quick-cocos2d-x之testlua之VisibleRect.lua quick-cocos2d-x之testlua之mainMenu.lua
AngularJs自定义指令详解(6) - controller、require
开发手游啦啦啦 · 2015-07-05 · via 博客园 - 开发手游啦啦啦

在前面文章中提到一旦声明了require,则链接函数具有第四个参数:controller。

可见require和controller是配合使用的。

在自定义指令中使用controller,目的往往是要封装一些行为,给其他指令使用。下面是一个简单的例子:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <script src="../lib/angular-1.3.16/angular.min.js"></script>
    <title></title>
    <script language="JavaScript">
        var app = angular.module('myapp',[]);

        app.directive('d1',function() {
            return {
                controller: function ($scope) {
                    this.method1 = function () {
                        return 'World';
                    };
                }
            }
        });

        app.directive('d2',function() {
            return {
                require: 'd1',
                link: function (scope, elem, attrs, d1) {
                    scope.greeting = d1.method1();
                }
            }
        });
    </script>
</head>
<body ng-app="myapp">
<div d1 d2>Hello {{greeting}}!</div>
</body>
</html>

输出:

Hello World!

从这个例子可以看到,在DOM中需要声明d1、d2,如果不声明d1,那么d2在检查require里的'd1'时,就会抛出异常。

AngularJs为我们提供了一些标记,使用它们可以告诉AngularJs怎么查找所require的控制器:

1,没标记。在当前元素中查找,如果找不到就抛出错误。

2,?标记。在当前元素中查找,如果查找不到,不抛出错误,链接函数的第四个参数为null(如上面代码link: function (scope, elem, attrs, d1)中的d1)

3,^标记。不仅在当前元素中查找,还查找其所有父级。如果找不到就抛出错误。

4,^^标记。只在当前元素的父级中查找。如果找不到就抛出错误。

5,?^标记。不仅在当前元素中查找,还查找其所有父级。如果查找不到,不抛出错误,链接函数的第四个参数为null

6,?^^标记。只在当前元素的父级中查找。如果查找不到,不抛出错误,链接函数的第四个参数为null

我们修改一下上面例子的代码,试验一下第4条:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <script src="../lib/angular-1.3.16/angular.min.js"></script>
    <title></title>
    <script language="JavaScript">
        var app = angular.module('myapp',[]);

        app.directive('d1',function() {
            return {
                controller: function ($scope) {
                    this.method1 = function () {
                        return 'World';
                    };
                }
            }
        });

        app.directive('d2',function() {
            return {
                require: '^^d1',
                link: function (scope, elem, attrs, d1) {
                    scope.greeting = d1.method1();
                }
            }
        });
    </script>
</head>
<body ng-app="myapp">
<div d1 d2>Hello {{greeting}}!</div>
</body>
</html>

在Chrome浏览器的控制台可以看到错误提示:

Error: [$compile:ctreq] http://errors.angularjs.org/1.3.16/$compile/ctreq?p0=d1&p1=d2

点击链接去看看(需要FQ):

Error: $compile:ctreq

Missing Required Controller

Controller 'd1', required by directive 'd2', can't be found!

果然找不到!因为d1放在d2所在的div中(当前元素),^^标记要求去父级找,当然没有了。

在实际应用时,我们往往会require 'ngModel',也就是希望利用AngularJs内置指令ngModel里的方法,而不是自己重新写:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <script src="../lib/angular-1.3.16/angular.min.js"></script>
    <title></title>
    <script language="JavaScript">
        var app = angular.module('myApp',[]);

        app.directive('myDirective',function() {
            return {
                require: 'ngModel',
                link: function (scope, elem, attrs, model) {
                    model.$parsers.unshift(function(value) {
                        if (parseFloat(value)<1) {
                            model.$setValidity('test', true);
                            return parseFloat(value).toFixed(2);
                        } else {
                            model.$setValidity('test', false);
                            return undefined;
                        }
                    });
                }
            }
        });

    </script>
</head>
<body ng-app="myApp">
<form name="form1">
     <div> 请输入小于1的一个小数:<input name="input1" type="number" ng-model="aNumber" my-directive />
            保留小数点后2位:{{aNumber}}
     </div>
    <span ng-show="form1.input1.$error.test">这个数并不小于1!</span>
</form>
</body>
</html>

上面例子就是利用了ngModel里已有的$parser属性和$setValidity方法。

$parsers里保存了一组function, 每当DOM里数据变化的时候, 这组function会被调用。