javascript代码实例教程-为什么使用AngularJS 指令?

发布时间:2019-02-01 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了javascript代码实例教程-为什么使用AngularJS 指令?脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。 使用过 AngularJS 的朋友应该最感兴趣的是它的指令。现今市场上的前端框架也只有AngularJS 拥有自定义指令的功能,并且AngularJS 是目前唯一提供Web应用可复用能力的框架。

 

目前有很多JavaScript 产品提供插件给Web开发人员。例如, Bootstrap 就是当前比较流行的提供样式和JavaScript插件的前端开发工具包。但是开发人员在使用Booostrap中的插件时, 必须切换到JavaScript 模式来写 jQuery 代码来激活插件虽然jquery 代码写起来十分简单,但是必须和HTML进行同步,这是一个单调乏味且容易出错的过程。

 

AngularJS主页展示了一个简单的例子,用于实现Bootstrap中的 Tab功能,可以在页面中轻松添加 Tab 功能,并且使用方法和 ul 标签一样简单。HTML代码如下:

 

复制代码

<body ng-app="components"> 

  <h3>BootStrap Tab Component</h3> 

  <tabs> 

    <pane tITle="First Tab"> 

      <p>This is the content of the first tab.</p> 

    </pane> 

    <pane title="Second Tab"> 

      <p>This is the content of the second tab.</p> 

    </pane> 

  </tabs> 

</body>

复制代码

 

 

JavaScript代码如下:

 

复制代码

angular.module(&#39;components', []). 

  directive('tabs', function() { 

    return { 

      restrict: 'E', 

      transclude: true, 

      scoPE: {}, 

      controller: [ "$scope", function($scope) { 

        VAR panes = $scope.panes = []; 

  

        $scope.select = function(pane) { 

          angular.foreach(panes, function(pane) { 

            pane.selected = false; 

          }); 

          pane.selected = true; 

        } 

  

        this.addPane = function(pane) { 

          if (panes.length == 0) $scope.select(pane); 

          panes.push(pane); 

        } 

      }], 

      template: 

        '<p class="tabbable">' + 

          '<ul class="nav nav-tabs">' + 

            '<li ng-repeat="pane in panes" ng-class="{active:pane.selected}">'+ 

              '<a href="" ng-click="select(pane)">{{pane.title}}</a>' + 

            '</li>' + 

          '</ul>' + 

          '<p class="tab-content" ng-transclude></p>' + 

        '</p>', 

      replace: true 

    }; 

  }). 

  directive('pane', function() { 

    return { 

      require: '^tabs', 

      restrict: 'E', 

      transclude: true, 

      scope: { title: '@' }, 

      link: function(scope, element, attrs, tabsCtrl) { 

        tabsCtrl.addPane(scope); 

      }, 

      template: 

        '<p class="tab-pane" ng-class="{active: selected}" ng-transclude>' + 

        '</p>', 

      replace: true 

    }; 

  })

复制代码

 

 

你可以从以下链接查看效果:https://jsfiddle.net/powertoolsteam/GBE7N/1/

 

image

 

正如你所见,除了拥有用于实现指令的 <tabs> 和<pane> 标签,页面和常规HTML页面没有什么区别。HTML开发人员无需编写任何代码。当然,总需要有第一个螃蟹的人,创建指令共享使用,但是目前Tabs指令已经很常见了,可以在任何地方复用(如BootStrap,、jQueryUI、Wijmo, 和一些知名的前端插件集)。

 

由于指令的易用和易编写,许多用户已经开始使用AngularJS编写指令了。例如, AngularJS 开发组已经基于AngularJS实现了一系列指令-UI Bootstrap 来代替Bootstrap; 知名ComponentOne 控件厂商也在AngularJS 基础上创建了Wijmo ;我们也可以在GitHub上找到一些公共指令资料库:jQueryUI widgets。

 

拥有了 AngularJS,是不是觉得自己已经站在了巨人的肩膀上了?但是不要高兴的太早,如果已经有了这么多的指令供我们使用,那我们为什么还要学习AngularJS ,为什么还要学习自定义指令呢?

 

举个简单的例子,也许你有特殊的需求:假设你在一家财务公司工作,你需要创建一张财务表单,它需要以表格的形式展示数据、拥有绑定、编辑、校验并且同步数据更新到服务器的功能。表单插件很常见但是能够满足这些具体需求的不得而知了,所以你必须根据实际业务需求来创建自定义指令。

 

复制代码

<body ng-app="abcFinance"> 

  <h3>Offshore Investment Summary</h3> 

  <abc-investment-form 

    customer="currentCustomer" 

    country="currentCountry"> 

  </abc-investment-form data> 

</body> 

复制代码

 

 

这就是本篇文章的目的,接下来我们会讨论如何创建 AngularJS指令。

 

 

 

创建自定义AngularJS 指令

文章开头的自定义指令十分的简单。它仅仅实现了同步的功能。一般指令是包含更多元素的:

 

复制代码

//创建指令模块 (或者检索现有模块) 

var m = angular.module(";myApp");

 

// 创建"my-dir"指令 

myApp.directive("myDir", function() { 

  return { 

    restrict: "E",        // 指令是一个元素 (并非属性) 

    scope: {              // 设置指令对于的scope 

      name: "@",          // name 值传递 (字符串,单向绑定) 

      amount: "=",        // amount 引用传递(双向绑定) 

      save: "&"           // 保存操作 

    }, 

    template:             // 替换HTML (使用scope中的变量) 

      "<p>" + 

      "  {{name}}: <input ng-model='amount' />" + 

      "  <button ng-click='save()'>Save</button>" + 

      "</p>", 

    replace: true,        // 使用模板替换原始标记 

    transclude: false,    // 不复制原始HTML内容 

    controller: [ "$scope", function ($scope) { …  }], 

    link: function (scope, element, attrs, controller) {…} 

  } 

});  

复制代码

 

 

效果如下:

 

image

 

 

注意这个自定义指令遵循一种格式:以"my" 为前缀,类似于命名空间,因此如果你在应用中引用了多个模块指令,你可以通过前缀很容易的判断出它是在哪定义的。这不是硬性要求,但是这样做可以带来很多便利。

 

指令的构造函数会返回带有属性的JavaScript 对象。这些内容在AngularJS 主页中都有清晰说明。以下是我对一些属性的理解:

 

restrict: 说明指令在HTML中的应用形式,备选项有"A"、"E" 和 "C", "M" ,分别代表 attribute、element、class和comment(默认值为"A")。我们将更多的关注attributes-如何创建UI元素。

scope: 创建指令的作用范围,scope在指令中作为属性标签传递。Scope 是创建可以复用指令的必要条件,每个指令(不论是处于嵌套指令的哪一级)都有其唯一的作用域,它不依赖于父scope。scope 对象定义names 和types 变量。上面的例子即创建了3个scope变量。

name: "@" (值传递,单向绑定): 

"@"符号表示变量是值传递。指令会检索从父级scope中传递而来字符串中的值。指令可以使用该值但无法修改,是最常用的变量。

amount: "=" (引用,双向绑定) 

"="符号表示变量是引用传递。指令检索主Scope中的引用取值。值可以是任意类型的,包括复合对象和数组。指令可以更改父级Scope中的值,所以当指令需要修改父级Scope中的值时我们就需要使用这种类型。

save: "&" (表达式) 

“&”符号表示变量是在父级Scope中启作用的表达式。它允许指令实现比修改值更高级的操作。

template: 替代原始模板中的标记的字符串。替换功能将替换所有旧元素为新值。注意template是如何使用Scope中定义的变量的。这允许你无需写任何额外的代码即可创建macro-style 风格指令。replace: 说明是否替换原始标记中的值或是追加原始标记中的值。默认值是false,这时原始标记将被保留。

transclude: 说明自定义指令是否复制原始标记中的内容。例如,之前展示的“tab”指令设置了transclude 为 true,因为tab 元素包含其他HTML 元素。 "dateinput" 指令则需要在初始化时为空,所以需要设置transclude 为false。

link: 该方法在指令中扮演着重要的角色。它负责执行DOM 操作和注册事件监听器等。link 方法包含以下参数:

scope: 指令Scope的引用。scope 变量在初始化时是不被定义的,link 方法会注册监视器监视值变化事件。

element: 包含指令的DOM元素的引用, link 方法一般通过jQuery 操作实例(如果没有加载jQuery,还可以使用Angular's jqLite )。

controller: 在有嵌套指令的情况下使用。这个参数作用在于把子指令的引用提供给父指令,允许指令之间进行交互, tab 指令就是使用该参数较典型的例子:https://jsfiddle.net/powertoolsteam/GBE7N/1/

注意,当调用link 方法时, 通过值传递("@")的scope 变量将不会被初始化,它们将会在指令的生命周期中另一个时间点进行初始化,如果你需要监听这个事件,可以使用scope.$watch 方法。 

觉得可用,就经常来吧! 脚本宝典 欢迎评论哦! js脚本,巧夺天工,精雕玉琢。小宝典献丑了!

脚本宝典总结

以上是脚本宝典为你收集整理的javascript代码实例教程-为什么使用AngularJS 指令?全部内容,希望文章能够帮你解决javascript代码实例教程-为什么使用AngularJS 指令?所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。