为了账号安全,请及时绑定邮箱和手机立即绑定

angularjs自定义指令Directive

标签:
AngularJS

今天学习angularjs自定义指令Directive。
Directive是一个非常棒的功能。可以实现我们自义的的功能方法。

下面的例子是演示用户在文本框输入的帐号是否为管理员的帐号"Admin"。

在网页上放一个文本框和一个铵钮:



<form id="form1" name="form1" ng-app="app" ng-controller="ctrl" novalidate>        <input id="Text1" type="text" ng-model="Account" is-Administrator/>        <br />        <input id="ButtonVerify" type="button" value="Verify" ng-click="Verify();" />    </form>

Source Code


然后你需要引用angularjs的类库:

 @Scripts.Render("~/bundles/angular")


以上是ASP.NET MVC bundle了。

定义一个App:

 var app = angular.module('app', []);

 

 定义一个控制器:


 

app.controller('ctrl', function ($scope) {            $scope.Account;            $scope.Verify = function () {                if ($scope.form1.$valid) {                    alert('OK.');                }                else {                    alert('failure.');                }            };        });

Source Code


下面是重点代码,自定义指令:


app.directive("isAdministrator", function ($q, $timeout) {            var adminAccount = "Admin";            var CheckIsAdministrator = function (account) {                return adminAccount == account ? true : false;            };            return {                restrict: "A",                require: "ngModel",                link: function (scope, element, attributes, ngModel) {                    ngModel.$asyncValidators.isAdministrator = function (value) {                        var defer = $q.defer();                        $timeout(function () {                            if (CheckIsAdministrator(value)) {                                defer.resolve();                            } else {                                defer.reject();                            }                        }, 700);                        return defer.promise;                    }                }            };        });

Source Code

 

演示:

 

 

点击查看更多内容
1人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消