AngularJS1.X學習筆記6-控制器和作用域

来源:http://www.cnblogs.com/floor/archive/2017/04/01/6657220.html
-Advertisement-
Play Games

經過一番艱苦卓絕的鏖戰,我終於來到了控制器和作用域部分。控制器作為MVC的C,其重要性不可謂不重要;作用域決定了你可以拿到哪些東西,亦是分外重要。現在就來學習一下兩個東西。去看看$apply,$watch,$broadcast是個什麼鬼。 ...


  經過一番艱苦卓絕的鏖戰,我終於來到了控制器和作用域部分。控制器作為MVC的C,其重要性不可謂不重要;作用域決定了你可以拿到哪些東西,亦是分外重要。現在就來學習一下兩個東西。去看看$apply,$watch,$broadcast是個什麼鬼。

一、談談MVC

  阮一峰老師說Angular是一個叫MVVM的模式(http://www.ruanyifeng.com/blog/2015/02/mvcmvp_mvvm.html),而自由男人說這是一個MVC框架,個人認為都差不多,目標都是分層,便於協作和維護,這個跟我們的電腦網路的分層思想差不多(可以參看http://www.cnblogs.com/floor/p/6649424.html)。下麵還是按照MVC的觀點看看Angular。

  ThinkPHP是一個服務端MVC框架,他的視圖就是我們前端的一切東西,控制器是從模型拿數據放到視圖,或者從視圖拿數據,交給模型,控制器是不直接與資料庫打交道的,與資料庫相關的操作就是模型的作用,我們在控制器調用M()方法就拿到了一個表對應的模型。

  前端MVC則有不同,對Angular 而言,controller()方法構建的就是控制器,$scope上的東西就可以理解為模型,他們一般是調用後端介面拿到的,視圖就是你看到的東西。

二、單一控制器

  這是最簡單的控制器應用形式,特點是控制器與視圖一一對應,無需考慮作用域之間的通信問題。缺點是隨著項目複雜度的增加可能變得難以維護。

  

<!DOCTYPE html>
<html lang="en" ng-app='myApp'>
<head>
    <meta charset="UTF-8">
    <title>single controller</title>
</head>
<body>
    <div ng-controller='dayCtrl'>
        <div>
            <h3>singleController</h3>
        </div>
        <h4>Today is {{day || "(不曉得)"}}</h4>
    </div>

    

    <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
    <script type="text/javascript">
        var myApp = angular.module("myApp",[]);
        myApp.controller('dayCtrl',function($scope){
            var dayNames = ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'];
            $scope.day = dayNames[new Date().getDay()];

        })
    </script>
</body>
</html>

三、一個控制器管幾個作用域

  自由男人給出了這樣一個圖

  由此可見,將一個控制器用於多個沒有重合不部分的HTML相當於建立了多個控制器實例,他們對應多個作用域,控制器實例之間互不相干,作用域之間也互不相干。可以做個測試看看

<!DOCTYPE html>
<html lang="en" ng-app='myApp'>
<head>
    <meta charset="UTF-8">
    <title>use an controller more than once</title>
</head>
<body>
    <div ng-controller='testCtrl'>
        我是一個域:<input type="text" name="" ng-model="data">
    </div>
    <div ng-controller='testCtrl'>
        我是另一個域:<input type="text" name="" ng-model="data">
    </div>

    

    <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
    <script type="text/javascript">
        var myApp = angular.module("myApp",[]);
        myApp.controller('testCtrl',function($scope){
            $scope.data="數據"

        })
    </script>
</body>
</html>

 

  結果是在任何一個文本框輸入都不會影響到另一個文本框,因為他們是相互隔離的。

四、作用域通信

  上面講到將一個控制器用於幾個視圖會產生幾個隔離的作用域,但是有時候需要一部分數據能夠共用,此時就應該使用$rootScope了。

  

<!DOCTYPE html>
<html lang="en" ng-app='myApp'>
<head>
    <meta charset="UTF-8">
    <title>use an controller more than once</title>
</head>
<body>
    <div ng-controller='testCtrl'>
        我是一個域:name:<input type="text" name="" ng-model="name"><br>
        sex:<input type="text" name="" ng-model="sex">
    </div>
    <div ng-controller='testCtrl'>
        我是一個域:name:<input type="text" name="" ng-model="name"><br>
        sex:<input type="text" name="" ng-model="sex">
    </div>

    

    <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
    <script type="text/javascript">
        var myApp = angular.module("myApp",[]);
        myApp.controller('testCtrl',function($scope,$rootScope){
            $scope.sex="";
            $scope.name = "大~熊";
            $scope.$watch('sex',function(){
                $rootScope.$broadcast("sexChange",$scope.sex);
            });
            $scope.$on('sexChange',function(event,args){
                $scope.sex = args;
            })

        })
    </script>
</body>
</html>

  本想著做個gif展示一下的,發現ubuntu下做個gif有點麻煩,這個說明sex有倆個作用域共用,而name則是獨享的。$rootScope可以認為是一個頂層作用域,他能夠訪問到其他子域,本例中,通過監聽sex的變化,如果變化,則通過$rootScope發送一個sexChange事件,並將sex作為參數傳進去,然後在$scope上偵聽該事件,如果事件被觸發,則改變$scope.sex為傳進來的新值。

五、控制器的繼承

  一個控制器的視圖包含另一個控制器,那麼裡面的控制器將繼承外面的控制器放到$scope上的屬性和方法。

  

<!DOCTYPE html>
<html lang="en" ng-app='myApp'>
<head>
    <meta charset="UTF-8">
    <title>繼承</title>
</head>
<body>
    <div ng-controller='fatherCtrl'>
        <div ng-controller="sonCtrl">
            <h1>{{data}}</h1>
        </div>
    </div>
    

    <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
    <script type="text/javascript">
        var myApp = angular.module("myApp",[]);
        myApp.controller('fatherCtrl',function($scope,$rootScope){
            $scope.data = "愚人節快樂!";

        })
        .controller("sonCtrl",function(){

        });
    </script>
</body>
</html>

  sonCtrl中並沒有任何東西,但是它從fatherCtrl中繼承了data屬性(值為:愚人節快樂!);

六、關於顯示更新作用域

方法 幹啥的
$apply(expression) 向作用域中應用變化
$watch(expression,hadler) expression發生變化執行handler
$watchCollection(object,handler) object任一屬性變化則執行handler

 

<!DOCTYPE html>
<html lang="en" ng-app='myApp'>
<head>
    <meta charset="UTF-8">
    <title>updataScope</title>
</head>
<body>
    <div ng-controller='dayCtrl'>
        <h1>{{data}}</h1>
    </div>

    

    <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
    <script type="text/javascript">
        var myApp = angular.module("myApp",[]);
        myApp.controller('dayCtrl',function($scope){
            $scope.data = "愚人節快樂!";
            
            setTimeout(function () {
                $scope.$apply(function () {
                   $scope.data ="大家愚人節快樂!";
                  });
              }, 1000);
        })
    </script>
</body>
</html>

  $watch()在上面的作用域通信已經用過了,$watchCollection()與之類似,關於這個$apply()我還不太清楚它有何作用。有知道的同學請指點一下。

  先寫到這,過幾天繼續,要複習,要考試!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 複習CSS時發現很多選擇器不會,因為平時很少用到。現在乾脆一不做二不修,全部溫習一遍。本文參考http://css.doyoe.com/. ...
  • 總結了三種非同步請求方式,XHR、Promise和Fetch,以及兩種跨域方案JSONP和CORS。文章淺顯移動,圖片豐富。不信?你進來看啊。 ...
  • 1.onclick事件 <button type="button" onclick="alert('Welcome!')">點擊這裡</button> <div onclick="alert('Welcome!')">點擊這個div</div> 2.改變 HTML 內容 添加按鈕,並調用onclic ...
  • 今天複習css時發現::的css選擇器,查了一下,知道有偽元素和偽類這件事,他們的區別是什麼呢?很幸運已經有人總結好了!CSS3偽類和偽元素的特性和區別。前端er們大都或多或少地接觸過CSS偽類和偽元素,比如最常見的:focus,:hover以及標簽的:link、visited等,偽元素較常見的比如... ...
  • <img class="desc_img" src="https://image.baidu.com/search/detail?ct=503316480&z=0&ipn=d&word=js&step_word=&hs=0&pn=0&spn=0&di=71153791170&pi=0&rn=1&tn... ...
  • 作用域是什麼? 作用域是什麼? 答:在《你不知道的javascript》書中提到,作用域就是根據名稱查找變數的一套規則。古語有“無規矩不成方圓”,但是沒有方圓,規矩又給誰用?所以個人理解作用域就是“規矩”+”方圓“。 書中提到作用域共有兩種主要的工作模型。第一種是詞法作用域,另外一種叫作動態作用域。 ...
  • javascript: 基於瀏覽器 基於對象 事件驅動 腳本語言 由: javascript: ECMAscript(ES) DOM文檔對象模型 BOM瀏覽器對象模型,三部分組成 使用js的三種方式 1.HTML標簽中內嵌js:<button ondblclick="javascript:alert ...
  • randomjson用來根據模型隨機生成json,mock json數據的時候特別有用 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...