国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

angular中實(shí)現(xiàn)控制器之間傳遞參數(shù)的方式

2024-05-06 15:18:07
字體:
供稿:網(wǎng)友

在angular中,每個controller(控制器)都會有自己的$scope,通過為這個對象添加屬性賦值,就可以將數(shù)據(jù)傳遞給模板進(jìn)行渲染,每個$scope只會在自己控制器內(nèi)起作用,而有時候需要用到其他控制器中的數(shù)據(jù),這個時候就要考慮到控制器之間參數(shù)的傳遞了。

1.通過$rootscope傳參

首先,在angular中存在作用域的繼承,繼承作用域符合 JavaScript 的原型繼承機(jī)制,這意味著如果我們在子作用域中訪問一個父作用域中定義的屬性,JavaScript 首先在子作用域中尋找該屬性,沒找到再從原型鏈上的父作用域中尋找,如果還沒找到會再往上一級原型鏈的父作用域?qū)ふ摇T?AngularJS 中,作用域原型鏈的頂端是$rootScope,AnguarJS 將會尋找到$rootScope 為止,如果還是找不到,則會返回 undefined。

<div ng-app="app">    <div ng-controller="parent">      {{name}}      <div ng-controller="son">      {{name}}      </div>    </div>  </div>  var app=angular.module("app",[]);  app.controller('parent', ['$scope',function ($scope) {    $scope.name="hello";  }]);  app.controller('son', ['$scope',function ($scope) {    console.log($scope.name);//hello  }]);

在子控制器中打印name,但我們發(fā)現(xiàn)在這個控制器中并未為$scope添加name,于是向父作用域查找,發(fā)現(xiàn)父作用域存在該屬性,所以可以打印出來。

$rootscope 是所有 $scope 的最上層對象,可以理解為一個 Angular 應(yīng)用中的全局作用域?qū)ο蟆K詾?rootscope添加的屬性,在所有的控制器中都可以訪問得到。但是為它附加太多邏輯或者變量并不是一個好主意,和js全局污染是一樣的.

2.通過事件的方式

首先介紹一下angular中的事件廣播:

$on(name,handler) 注冊一個事件處理函數(shù),該函數(shù)在特定的事件被當(dāng)前作用域收到(從父級或者子級作用域)時將被調(diào)用。

$emit(name,args) 向當(dāng)前父作用域發(fā)送一個事件,直至根作用域。

$broadcast(name,args) 向當(dāng)前作用域下的子作用域發(fā)送一個事件。

name表示事件名稱,args表示事件傳播的數(shù)據(jù),handler表示在接受到傳遞時要執(zhí)行的回調(diào),該回調(diào)中有event參數(shù),表示事件,有如下方法:

    event.targetScope 獲取傳播事件的作用域 event.currentScope 獲取接收事件的作用域 event.name 傳播的事件的名稱 event.stopPropagation() 阻止事件進(jìn)行冒泡傳播,僅在$emit事件中有效 event.preventDefault() 阻止傳播事件的發(fā)生   event.defaultPrevented 如果調(diào)用了preventDefault事件則返回true

1)子向父控制器傳值

<div ng-app="app">    <div ng-controller="parent">      {{name}}      <div ng-controller="son">      {{name}}      </div>    </div>  </div>  var app=angular.module("app",[]);  app.controller('parent', ['$scope',function ($scope) {    $scope.$on('call', function(event,data){      $scope.name=data;      console.log(data);    });  }]);  app.controller('son', ['$scope',function ($scope) {    $scope.name="hello";    $scope.$emit('call', $scope.name);  }]);            
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 林芝县| 大石桥市| 鹤峰县| 上虞市| 常州市| 三台县| 静宁县| 西宁市| 盐亭县| 潜江市| 五大连池市| 壶关县| 肃北| 尼玛县| 龙南县| 和硕县| 眉山市| 体育| 汝阳县| 三江| 莱西市| 西吉县| 和平区| 南和县| 定远县| 昌图县| 界首市| 锦州市| 肥城市| 马尔康县| 仪征市| 平谷区| 赣州市| 平罗县| 七台河市| 车险| 阿坝| 石林| 清新县| 广丰县| 乌鲁木齐县|