六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

angular的scopel指令使用詳細說明

[摘要]這次給大家帶來angular的scopel指令使用詳解,使用angular的scopel指令注意事項有哪些,下面就是實戰案例,一起來看一下。我們來創建一個自定義指令<!DOCTYPE html><html lang="en"><head>&l...
這次給大家帶來angular的scopel指令使用詳解,使用angular的scopel指令注意事項有哪些,下面就是實戰案例,一起來看一下。

我們來創建一個自定義指令

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .primary{            background: red;
        }    </style></head><body ng-app="myApp">
    <div ng-controller="mainCtrl">
        <my-btn></my-btn>
    </div>
    <script src="node_modules/angular/angular.min.js"></script>
    <script>
        var myApp = angular.module('myApp',[]);
        myApp.controller('mainCtrl',['$scope',function($scope){
            $scope.myClass = 'primary';
        }]);
        myApp.directive('myBtn',function(){            return {
                template:'<input type="button" value="按鈕" class="{{myClass}}">'
            }
        });    </script></body></html>


1.png

使用自定義指令像上面一樣的確不錯,但是如果你想要對每一個指令渲染出來的按鈕定制化,則好像不可以,比如下面我們創建一堆這個自定義指令,他們長得一模一樣:

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .primary{            background: red;
        }    </style></head><body ng-app="myApp">
    <div ng-controller="mainCtrl">
        <my-btn></my-btn>
        <my-btn></my-btn>
        <my-btn></my-btn>
        <my-btn></my-btn>
    </div>
    <script src="node_modules/angular/angular.min.js"></script>
    <script>
        var myApp = angular.module('myApp',[]);
        myApp.controller('mainCtrl',['$scope',function($scope){
            $scope.myClass = 'primary';
        }]);
        myApp.directive('myBtn',function(){            return {
                template:'<input type="button" value="按鈕" class="{{myClass}}">'
            }
        });    </script></body></html>


2.png

一種思路是把這幾個自定義的指令按鈕放到不同的控制器里面,然后控制器里通過$scope上下文傳遞不同的值:


  <!DOCTYPE html><html><head>
   <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .primary{            background: red;
        }        .success{            background: green;
        }        .default{            background: gray;
        }    </style></head><body ng-app="myApp">
    <div ng-controller="aCtrl">
        <my-btn></my-btn>
    </div>
    <div ng-controller="bCtrl">
        <my-btn></my-btn>
    </div>
    <div ng-controller="cCtrl">
        <my-btn></my-btn>
    </div>
    <script src="node_modules/angular/angular.min.js"></script>
    <script>
        var myApp = angular.module('myApp',[]);
        myApp.controller('aCtrl',['$scope',function($scope){
            $scope.myClass = 'primary';
        }]);
        myApp.controller('bCtrl',['$scope',function($scope){
            $scope.myClass = 'success';
        }]);
        myApp.controller('cCtrl',['$scope',function($scope){
            $scope.myClass = 'default';
        }]);
        myApp.directive('myBtn',function(){            return {
                template:'<input type="button" value="按鈕" class="{{myClass}}">'
            }
        });    </script></body></html>

3.png

這樣寫太麻煩了,所以我們的angular為我們的自定義指令提供了一個配置項叫scope,所以,我們可以如下這樣寫:

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .primary{            background: red;
        }        .success{            background: green;
        }        .default{            background: gray;
        }    </style></head><body ng-app="myApp">
    <div ng-controller="Controller">
      <my-btn b="className1"></my-btn>
      <my-btn b="className2"></my-btn>
      <my-btn b="className3"></my-btn>
    </div>
    <script src="node_modules/angular/angular.min.js"></script>
    <script>
        var myApp = angular.module('myApp',[]);
        
        myApp
        .controller('Controller', ['$scope', function($scope) {
          $scope.className1 = 'primary';
          $scope.className2 = 'success';
          $scope.className3 = 'default';
        }])
        .directive('myBtn',function(){            return {
                scope:{
                    a:'=b'
                },
                template:'<input type="button" value="按鈕" class="{{a}}">'
            }
        });    </script></body></html>

要看懂上面的只要注意兩點:

這里的獨立作用域里面的a代表的是template里面的模型a

=b代表的是要angular去尋找視圖里面的當前指令的屬性b

屬性b的值需要去外部作用域里面去尋找

如果你想在指令作用域里綁定的模型的名字和外部使用的時候的屬性名一樣,可以省寫成如下:

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .primary{            background: red;
        }        .success{            background: green;
        }        .default{            background: gray;
        }    </style></head><body ng-app="myApp">
    <div ng-controller="Controller">
      <my-btn a="className1"></my-btn>
      <my-btn a="className2"></my-btn>
      <my-btn a="className3"></my-btn>
    </div>
    <script src="node_modules/angular/angular.min.js"></script>
    <script>
        var myApp = angular.module('myApp',[]);
        
        myApp
        .controller('Controller', ['$scope', function($scope) {
          $scope.className1 = 'primary';
          $scope.className2 = 'success';
          $scope.className3 = 'default';
        }])
        .directive('myBtn',function(){            return {
                scope:{
                    a:'='
                },
                template:'<input type="button" value="按鈕" class="{{a}}">'
            }
        });    </script></body></html>

當然,上面的=號是雙向數據綁定:

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .primary{            background: red;
        }        .success{            background: green;
        }        .default{            background: gray;
        }    </style></head><body ng-app="myApp">
    <div ng-controller="Controller">
      <my-btn a="abc"></my-btn>
    </div>
    <script src="node_modules/angular/angular.min.js"></script>
    <script>
        var myApp = angular.module('myApp',[]);
        
        myApp
        .controller('Controller', ['$scope', function($scope) {
          $scope.abc = '我是初始內容';
        }])
        .directive('myBtn',function(){            return {
                scope:{
                    a:'='
                },
                template:'<input type="text"  ng-model="a"><span>{{a}}</span>'
            }
        });    </script></body></html>

如果只是想單向的數據通信,可以用@符號:

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .primary{            background: red;
        }        .success{            background: red;
        }        .default{            background: red;
        }    </style></head><body ng-app="myApp">
    <div ng-controller="Controller">
      <my-btn a="primary"></my-btn>
    </div>
    <script src="node_modules/angular/angular.min.js"></script>
    <script>
        var myApp = angular.module('myApp',[]);
        
        myApp
        .controller('Controller', ['$scope', function($scope) {
          $scope.mm = 'primary';
        }])
        .directive('myBtn',function(){            return {
                scope:{
                    a:'@'
                },
                template:'<input type="button" value="按鈕" class="{{a}}">'
            }
        });    </script></body></html>

如果想用ng-class,也是可以的:

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .primary{            background: red;
        }        .success{            background: red;
        }        .default{            background: red;
        }    </style></head><body ng-app="myApp">
    <div ng-controller="Controller">
      <my-btn a="primary"></my-btn>
    </div>
    <script src="node_modules/angular/angular.min.js"></script>
    <script>
        var myApp = angular.module('myApp',[]);
        
        myApp
        .controller('Controller', ['$scope', function($scope) {
          $scope.mm = true;
        }])
        .directive('myBtn',function(){            return {
                scope:{
                    a:'@'
                },
                template:'<input type="button" value="按鈕" ng-class="{primary:a}">'
            }
        });    </script></body></html>

最后,還有一個scope可以設置是引用外部作用域的方法

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .primary{            background: red;
        }        .success{            background: red;
        }        .default{            background: red;
        }    </style></head><body ng-app="myApp">
    <div ng-controller="Controller">
      <my-btn fn2="fn()"></my-btn>
    </div>
    <script src="node_modules/angular/angular.min.js"></script>
    <script>
        var myApp = angular.module('myApp',[]);
        
        myApp
        .controller('Controller', ['$scope', function($scope) {
          $scope.fn = function(){
            alert(11);
          }
        }])
        .directive('myBtn',function(){            return {
                scope:{
                    fn1:'&fn2'
                },
                template:'<input type="button" value="按鈕" ng-click="fn1()">'
            }
        });    </script></body></html>

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

Angular Material的使用詳解

css中id選擇器的命名規則有哪些

讓元素水平垂直居中冷門方法

以上就是angular的scopel指令使用詳解的詳細內容,更多請關注php中文網其它相關文章!


網站建設是一個廣義的術語,涵蓋了許多不同的技能和學科中所使用的生產和維護的網站。




主站蜘蛛池模板: 亚洲一区二区影视 | 日韩欧美系列 | 日本在线观看中文 | 手机看片日韩在线 | 深夜毛片| 日韩一级在线播放免费观看 | 一级做a| 亚洲欧美网站 | 天堂精品在线 | 香蕉久人久人青草青草 | 四虎网址换成什么了2021 | 啪啪网站免费 | 五月天婷婷在线观看视频 | 新版天堂资源中文在线 | 欧美一级二级三级视频 | 色综合天天综合高清网国产 | 日本高清免费在线 | 日本欧美一区二区三区 | 在线免费黄| 亚洲三级网站 | 日韩专区一区 | 亚洲福利一区福利三区 | 亚洲伊人成综合人影院小说 | 亚洲综合视频在线观看 | 四虎影院com| 热久久中文字幕 | 亚洲成a人片毛片在线 | 欧美一级高清片欧美国产欧美 | 青青青视频精品中文字幕 | 伊人资源 | 奇米色婷婷 | 日本欧美一区二区三区视频麻豆 | 人人爽天天碰天天躁夜夜躁 | 五月花激情网 | 亚洲成在人天堂在线 | 天堂在线最新版资源www | 日韩免费观看 | 天天夜干 | 中文字幕亚洲一区二区v@在线 | 日韩一级二级三级 | 天天综合网久久 |