继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

angularjs自定义指令Directive

安卓开发学习视频
关注TA
已关注
手记 299
粉丝 78
获赞 601

今天学习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

 

演示:

 

 

打开App,阅读手记
1人推荐
发表评论
随时随地看视频慕课网APP