源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Angularjs自定义指令Directive详解

  • 时间:2021-09-29 05:41 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Angularjs自定义指令Directive详解
今天学习angularjs自定义指令Directive。 Directive是一个非常棒的功能。可以实现我们自义的的功能方法。 下面的例子是演示用户在文本框输入的帐号是否为管理员的帐号"Admin"。 在网页上放一个文本框和一个铵钮: [url=http://files.jb51.net/file_images/article/201705/201705270935221.jpg][img]http://files.jb51.net/file_images/article/201705/201705270935221.jpg[/img] [/url]
<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', []); 
定义一个控制器: [url=http://files.jb51.net/file_images/article/201705/201705270935224.jpg][img]http://files.jb51.net/file_images/article/201705/201705270935224.jpg[/img] [/url]
app.controller('ctrl', function ($scope) {
   $scope.Account;
   $scope.Verify = function () {
    if ($scope.form1.$valid) {
     alert('OK.');
    }
    else {
     alert('failure.');
    }
   };
  });  
下面是重点代码,自定义指令: [url=http://files.jb51.net/file_images/article/201705/201705270935225.jpg][img]http://files.jb51.net/file_images/article/201705/201705270935225.jpg[/img] [/url]
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;
     }
    }
   };
  });
演示: [url=http://files.jb51.net/file_images/article/201705/201705270935226.gif][img]http://files.jb51.net/file_images/article/201705/201705270935226.gif[/img] [/url] 以上所述是小编给大家介绍的Angularjs自定义指令Directive详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部