JavaScript

超轻量级php框架startmvc

Angularjs自定义指令Directive详解

更新时间:2020-05-14 15:54:02 作者:startmvc
今天学习angularjs自定义指令Directive。Directive是一个非常棒的功能。可以实现我们自义的的功

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

然后你需要引用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.');
 }
 };
 }); 

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


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;
 }
 }
 };
 });

演示:

以上所述是小编给大家介绍的Angularjs自定义指令Directive详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

angularjs自定义指令 directive