" />

欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2017年04月24日 14:13:29   作者:北城以南  
本篇文章主要介紹了angular中實(shí)現(xiàn)控制器之間傳遞參數(shù)的方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。

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

1.通過$rootscope傳參

首先,在angular中存在作用域的繼承,繼承作用域符合 JavaScript 的原型繼承機(jī)制,這意味著如果我們?cè)谧幼饔糜蛑性L問一個(gè)父作用域中定義的屬性,JavaScript 首先在子作用域中尋找該屬性,沒找到再從原型鏈上的父作用域中尋找,如果還沒找到會(huì)再往上一級(jí)原型鏈的父作用域?qū)ふ摇T?AngularJS 中,作用域原型鏈的頂端是$rootScope,AnguarJS 將會(huì)尋找到$rootScope 為止,如果還是找不到,則會(huì)返回 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)在這個(gè)控制器中并未為$scope添加name,于是向父作用域查找,發(fā)現(xiàn)父作用域存在該屬性,所以可以打印出來。

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

2.通過事件的方式

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

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

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

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

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

  1. event.targetScope 獲取傳播事件的作用域
  2. event.currentScope 獲取接收事件的作用域
  3. event.name 傳播的事件的名稱
  4. event.stopPropagation() 阻止事件進(jìn)行冒泡傳播,僅在$emit事件中有效
  5. event.preventDefault() 阻止傳播事件的發(fā)生  
  6. 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);
  }]);

2)父向子控制器傳值

var app=angular.module("app",[]);
  app.controller('parent', ['$scope',function ($scope) {
    $scope.name="hello";
    $scope.$broadcast('call', $scope.name);//傳值
  }]);
  app.controller('son', ['$scope',function ($scope) {
    $scope.$on('call', function(event,data1){
      $scope.name1=data1;//接受值
      
    });
  }]);

注意:參數(shù)name相同時(shí),父子控制器之間才可以傳值

這種方式不可實(shí)現(xiàn)兄弟級(jí)傳值,不過可以使用父級(jí)控制器作為中介,先由子控制器傳值給父控制器,然后再由父控制器傳遞給另外的子控制器。

補(bǔ)充:之前遇到一個(gè)需求是,父控制器中,觸發(fā)change事件后,獲取數(shù)據(jù)傳遞給子控制,但是在子控制器只需要接受一次,發(fā)現(xiàn)可通過如下方式:

var scan=$scope.$on(name,handler);scan();這樣子控制器就只接受可一次,避免了多次接受帶來的影響!

3.通過服務(wù)

在angular中服務(wù)是一個(gè)單例,所以在服務(wù)中生成一個(gè)對(duì)象,該對(duì)象就可以利用依賴注入的方式在所有的控制器共享。

例:

var app=angular.module("app",[]);
  app.controller('myCtrl', ['$scope','appService',function ($scope,appService) {
    appService.name="hi!!"
  }]);
  app.controller('myCtrl1', ['$scope', 'appService',function ($scope,appService) {
    $scope.name=appService.name;
  }]);
  app.service("appService", [function(){
    this.name="hello";
  }]);

通過在appService這個(gè)服務(wù)中添加對(duì)象,然后在需要用到的控制器中,通過依賴注入的方式導(dǎo)入該服務(wù),在myCtrl控制器中修改這個(gè)對(duì)象,在myCtrl1中也會(huì)得到修改過后的值。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 掌握Queries設(shè)計(jì)模式優(yōu)化Angular應(yīng)用開發(fā)技巧

    掌握Queries設(shè)計(jì)模式優(yōu)化Angular應(yīng)用開發(fā)技巧

    這篇文章主要介紹了掌握Queries設(shè)計(jì)模式優(yōu)化Angular應(yīng)用開發(fā)的技巧示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • Angular2 PrimeNG分頁模塊學(xué)習(xí)

    Angular2 PrimeNG分頁模塊學(xué)習(xí)

    這篇文章主要為大家詳細(xì)介紹了Angular2 PrimeNG分頁模塊學(xué)習(xí)教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • AngularJS ng-app 指令實(shí)例詳解

    AngularJS ng-app 指令實(shí)例詳解

    本文主要介紹AngularJS ng-app 指令,這里整理了ng-app指令的一些資料,并附實(shí)例代碼,有需要的小伙伴可以參考下
    2016-07-07
  • 解析Angular 2+ 樣式綁定方式

    解析Angular 2+ 樣式綁定方式

    這篇文章主要介紹了解析Angular 2+ 樣式綁定方式,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • Angular事件之不同組件間傳遞數(shù)據(jù)的方法

    Angular事件之不同組件間傳遞數(shù)據(jù)的方法

    這篇文章主要介紹了Angular事件之不同組件間傳遞數(shù)據(jù)的方法,利用Angular Event在不同組件之間傳遞數(shù)據(jù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 詳解Angular2中Input和Output用法及示例

    詳解Angular2中Input和Output用法及示例

    這篇文章主要介紹了詳解Angular2中Input和Output用法及示例,對(duì)于angular2中的Input和Output可以和AngularJS中指令作類比,有興趣的可以了解一下
    2017-05-05
  • Angular項(xiàng)目如何使用攔截器?httpClient?請(qǐng)求響應(yīng)處理

    Angular項(xiàng)目如何使用攔截器?httpClient?請(qǐng)求響應(yīng)處理

    這篇文章主要介紹了Angular項(xiàng)目簡(jiǎn)單使用攔截器httpClient請(qǐng)求響應(yīng)處理,目前我的Angular版本是Angular?17.3,版本中實(shí)現(xiàn)請(qǐng)求和響應(yīng)的攔截處理了,這種機(jī)制非常適合添加如身份驗(yàn)證頭、錯(cuò)誤統(tǒng)一處理、日志記錄等功能,需要的朋友可以參考下
    2024-06-06
  • Angular2生命周期鉤子函數(shù)的詳細(xì)介紹

    Angular2生命周期鉤子函數(shù)的詳細(xì)介紹

    這篇文章主要介紹了Angular2生命周期鉤子函數(shù)的詳細(xì)介紹,Angular提供組件生命周期鉤子,可以讓我們更好的開發(fā)Angular應(yīng)用,有興趣的可以了解一下
    2017-07-07
  • 利用angular.copy取消變量的雙向綁定與解析

    利用angular.copy取消變量的雙向綁定與解析

    眾所周知AngularJS的雙向綁定在表單應(yīng)用中強(qiáng)大又方便,但是偶爾會(huì)遇到需要解除對(duì)象變量的雙向綁定。Angular提供的angular.copy的方法可以實(shí)現(xiàn)解除雙向綁定。所以這篇文章就來給大家詳細(xì)的介紹下angular.copy,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-11-11
  • 詳解angular中的作用域及繼承

    詳解angular中的作用域及繼承

    本篇文章主要介紹了詳解angular中的作用域及繼承,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05

最新評(píng)論