zoukankan      html  css  js  c++  java
  • angular学习笔记(三十)-指令(9)-一个简单的指令示例

    学了前面这么多关于指令的知识,现在就用指令来写一个小组件:expander

    这个组件的功能就是点击开展菜单,再点击收起菜单:

    ↑↓点击展开收起

    下面来看它的代码:

    html:

    <!DOCTYPE html>
    <html ng-app="expanderModule">
    <head>
      <title>20.9 指令-expander</title>
      <meta charset="utf-8">
      <link href="../bootstrap.css" rel="stylesheet">
      <script src="../angular.min.js"></script>
      <script type="text/ng-template" id="text.html">
        <div class="btn-group">
          <button class="btn btn-primary btn-sm dropdown-toggle" type="button" data-toggle="dropdown" ng-click="toggle()">
            {{title}}<span class="caret"></span>
          </button>
          <ul class="dropdown-menu" ng-show="ifShow" ng-transclude>
          </ul>
        </div>
      </script>
      <script src="script.js"></script>
      <style type="text/css">
        body{
          padding:40px
        }
      </style>
    </head>
    <body>
      <div ng-controller="expanderCtrl">
        <expander my-title="{{title}}">
          <li ng-repeat="content in contents">
            <a href="">{{content}}</a>
          </li>
        </expander>
      </div>
    </body>
    </html>

    js:

    /*20.9 指令*/
    var expanderModule = angular.module('expanderModule',[]);
    expanderModule.controller('expanderCtrl',function($scope){
        $scope.title = "标题";
        $scope.contents = ['bunny','cat','dog'];
    });
    expanderModule.directive('expander',function(){
        return {
            restrict:'EA',
            replace:true,
            templateUrl:'text.html',
            transclude:true,
            scope:{title:'@myTitle'},
            link:function(scope,ele,attrs){
                scope.ifShow = false;
                scope.toggle = function(){
                    scope.ifShow = !scope.ifShow;
                }
            }
        }
    });
    //指令元素里原本就包含的内容,他的作用域使用元素所在的作用域的父作用域,而不是指令的独立scope,所以contents值可以访问到控制器的contents,但是template里面的值却是访问指令独立作用域的.
    //这里的myTitle不会被修改,所以采用@和=绑定都可以

    下面来分析一下这个指令:

    1.创建一个名叫expander的指令,它的类型是元素

    2.指令元素里面放置的是子菜单的内容,注意是内容,不是整个ul.因为它要作为一坨插入到ng-transclude元素中,所以,ul必须充当ng-transclude这个元素的角色,然后设置transclue:true.

    3.指令的my-title属性用于绑定父作用域的title属性.在这个案例中,使用@绑定和使用=绑定都是可以的.

    4.在link函数里给指令独立scope添加ifShow属性.然后在ul子菜单里通过ng-show="ifShow"来绑定它的显示与隐藏

    5.在link函数里给指令独立scope添加toggle()方法,切换ifShow.然后给按钮绑定ng-click="toggle()",来改变ifShow的值.

    6.在控制器里添加相关的数据模型:title和contents

    *7.这一点很重要:

         我在expander指令元素里面写了:ng-repeat="content in contents".

         然后在text.html模板里写了:ng-click="toggle()" , {{title}} , ng-show="ifShow".

      对于expander指令元素来说,写在它里面的内容,它的作用域就是指令所在的元素的作用域,也就是父作用域,所以它可以访问到控制器里的contents模型.

      但是text.html,作为指令的模板,被替换到指令,写在模板里面的内容,它的作用域就是指令的独立作用域.也就是指令里定义的scope,所以它是不能访问到contents的,而toggle方法,ifShow属性,都已经在写link函数时,通过scope参数给指令独立作用域绑定了这两个属性和方法.title属性也通过@策略绑定父作用域的title属性.

         总结来说就是:原来就写在指令里面的内容,它的作用域还是父作用域,和指令的scope无关.

                          指令的template里面的内容,它的作用域是指令的作用域,就是定义指令时候写的scope属性

     

    完整代码:https://github.com/OOP-Code-Bunny/angular/blob/master/OREILLY/20.9%20%E6%8C%87%E4%BB%A4.html

                https://github.com/OOP-Code-Bunny/angular/blob/master/OREILLY/script.js

  • 相关阅读:
    人一生要去的100个地方(世界)
    数据仓库相关书籍
    学理财要看的书籍
    数仓设计 Building the Data Warehouse
    Google Cloud 安装java
    Google Cloud install python3 (in CentOS)
    SyntaxError: Non-ASCII character 'xe5' in file test23.py on line 2, but no encoding declared;
    CentOS 安装7z
    CentOS 安装 MySQL
    复杂迭代代码分析
  • 原文地址:https://www.cnblogs.com/liulangmao/p/3993261.html
Copyright © 2011-2022 走看看