茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    淺談angularJS中的事件
    來源:易賢網(wǎng) 閱讀:972 次 日期:2016-07-28 15:28:19
    溫馨提示:易賢網(wǎng)小編為您整理了“淺談angularJS中的事件”,方便廣大網(wǎng)友查閱!

    下面小編就為大家?guī)硪黄獪\談angularJS中的事件。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。

    什么是事件

    •如同瀏覽器響應(yīng)瀏覽器層的事件,比如鼠標點擊、獲得焦點,angular應(yīng)用也可以響應(yīng)angular事件

    •angular事件系統(tǒng)并不與瀏覽器的事件系統(tǒng)相通,我們只能在作用域上監(jiān)聽angular事件而不是DOM事件

    事件傳播

    因為作用域是有層次的,所以我們可以在作用域鏈上傳遞事件:

    •使用$emit冒泡事件,事件從當前子作用域冒泡到賦作用域,在產(chǎn)生事件的作用域之上的所有作用域都會收到這個事件的通知

    $emit()方法帶有兩個參數(shù):

    name  要發(fā)出的事件的名稱

    args   一個參數(shù)集合,作為對象傳遞到事件監(jiān)聽器上

    •使用$broadcast向下傳遞事件,每個注冊了監(jiān)聽器的子作用域都會收到這個信息

    $broadcast()方法帶有兩個參數(shù):

    name  要廣播的事件的名稱

    args   一個參數(shù)集合,作為對象傳遞到事件監(jiān)聽器上

    •使用$on監(jiān)聽事件

    $on()方法帶有兩個參數(shù):

    event  事件對象

    param  參數(shù)集合,$broadcast()、$emit()傳遞過來的參數(shù)集合  示例:

    demo.html

     <!doctype html>

     <html ng-app="freefedApp">

       <head>

         <title>angular應(yīng)用demo</title>

         <script src="angular.js"></script>

         <script src="app.js"></script>

      </head>

      <body>

      <div ng-controller="freefedCtrl">

         <div event-directive change="change(title)"></div>

       </div>

      </body>

     </html>

    -------------------------------------------

    app.js

     /*聲明module*/

     var module = angular.module('freefedApp',[]);

     /*聲明控制器*/

     module.controller('freefedCtrl',['$scope',function($scope){

         //監(jiān)聽directiveClick事件

         $scope.$on('directiveClick',function(event,param){

            console.log( param );  // 打印結(jié)果 {title : '我是來自指令子級作用域'}

         });

         $scope.change = function(title){

           var result = '請注意接收父級廣播';

           //向子級作用域廣播parentBroadcast事件

           $scope.$broadcast('parentBroadcast',{msg : result});

         };

     }]);

     /*聲明指令*/

     module.directive('eventDirective',function(){

        return {

           scope : {

             change : '&'

           },

          replace : true,

          template : '<a>點我向上冒泡事件</a>',

           link : function( scope,el,attr ){

             el.on('click',function(){

              //向上冒泡directiveClick事件,通知父級作用域

               scope.$emit('directiveClick',{title : '我是來自指令子級作用域'});

             });

            //監(jiān)聽parentBroadcast事件廣播

            scope.$on('parentBroadcast',function(event,msg){

               console.log( msg );  //打印結(jié)果 { msg : 請注意接收父級廣播 }

            });

           }

        };

     });

    事件對象屬性

    $on中的event事件對象屬性如下:

    •targetScope(作用域?qū)ο?

    發(fā)送或者廣播事件的作用域

    •currentScope(作用域?qū)ο?

    當前處理事件的作用域

    •name(字符串)

    正在處理事件的名稱

    •stopPropagation(函數(shù))

    stopPropagation()函數(shù)取消通過$emit觸發(fā)事件的進一步傳播

    •preventDefault(函數(shù)) preventDefault()把defaultprevented標志設(shè)置為true,盡管不能停止事件傳播,但是子作用域可以通過defaultprevented標志知道無需處理這個事件

    •defaultPrevented(布爾值)

    可以通過判斷defaultPrevented屬性來判斷父級傳播的事件是否可以去忽略

    以上這篇淺談angularJS中的事件就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考

    更多信息請查看網(wǎng)絡(luò)編程

    2026上岸·考公考編培訓報班

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)