AngularJS標準Web業務流程開發框架-4.AngularJS四大模塊之一:Controller

来源:https://www.cnblogs.com/witkeydu/archive/2018/09/15/9070142.html
-Advertisement-
Play Games

一、Controller的創建 1.name:控制器的名稱(建議參考Java包的命名規範:點的方式進行命名); 2.function:回調函數的構造方法(實際是對象,主要考慮到類的調用); 3.$scope相當於mvvm模式的viewmodel,支持變數、函數; 3.1.$ccope的由來: $in ...


一、Controller的創建

angular.controller("name",funtion($scope){

})

1.name:控制器的名稱(建議參考Java包的命名規範:點的方式進行命名);

2.function:回調函數的構造方法(實際是對象,主要考慮到類的調用);

3.$scope相當於mvvm模式的viewmodel,支持變數、函數;

3.1.$ccope的由來:

$injector註射完成後創建的$rootScope(根作用域root Viewmodel,$scope的父類)

3.2.$scope的作用

3.1.1.視圖和控制器的數據傳遞橋梁

3.1.2.封裝臟值檢查(dirtychecking),觸發臟值檢查的條件:

  1)$scope.$dirty(暴力臟值檢查,慎用)

  2)$scope.$apply(基於$dirty的封裝)

  3)$開頭的服務調用

  4)ng開頭的指令觸發  

4.控制器的創建支持鏈式寫法;

二、嵌套Controller值傳遞

1.內層控制器的值會覆蓋外層控制器的值,內層控制器不存在變數的值,外層控制器的值會作用於內層控制器的值;

2.內層控制器獲取外部控制器的值通過($scope.$parent)的方式獲取,多層嵌套則層層上拋;

三、平行Controller值共用

 通過$rootScope進行傳值

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 如果用安卓模擬器調試本機的網站,比如 localhost:63586,是訪問不到的,返回結果是 400 錯誤。原因是模擬器上的localhost指向的預設是模擬器自己。 解決方法是:(1) 把安卓模擬器訪問的 localhost 改成 10.0.2.2 (2) 如果是用 vs發佈的網站,預設發佈的U ...
  • 前言 在配置巨集定義參數時,會發現一個問題,在需要臨時修改或者測試一些數據時,修改巨集,如果不修改,就多寫一個,註釋掉原來的,然後測試後,再換回來,當然了,如果一兩個巨集,可以這樣,但是,如果每次改的比較多,建議用環境變數來配置,也就是用 xcconfig 控制 Debug 或 Release編譯時,同一 ...
  • 概述 ScreenMatch是根據你的需要,生成需要適配的尺寸的文件,手機會根據屏幕相關參數自動尋找合適的尺寸文件 添加插件 如圖,打開Android Studio的Settings設置,找到Plugins,點擊Browse Repositories,在彈出的輸入框里填入screenMatch,就可 ...
  • 一、butterknife介紹 ①官網 butterknife ②Field and method binding for Android Views which uses annotation processing to generate boilerplate code for you 【功能】 ...
  • 都說程式猿學習是不分平臺的,做了一輩子的Xaml,也想看看現在最牛逼的移動技術。 看了看Google 的Flutter,好像很牛逼,不怎麼需要Android和IOS基礎(應該還是要的), 不過現在是Beta版本,但是又說跟Fuschia 有關係,又是一個很牛逼的東西。 於是下載來品嘗一下。 先上幾個 ...
  • 概述 .9.PNG是安卓開發裡面的一種特殊的圖片,這種格式的圖片通過ADT自帶的編輯工具生成,使用九宮格切分的方法。點九圖是一種可拉伸的點陣圖,android會自動調整它的大小,來使圖像在充當背景時可以在界面中自適應展示 生成圖片 .9.png只能放在drawable文件夾中,右鍵.png圖片,找到如 ...
  • 參考文章:https://blog.csdn.net/qq_24216407/article/details/72842614 在build.gradle引用了Vlc的安卓包:de.mrmaffen:vlc-android-sdk:3.0.0 編譯一切正常,運行報錯: 大致意思是com.androi ...
  • 《一統江湖的大前端》系列是自己的前端學習筆記,旨在介紹javascript在非網頁開發領域的應用案例和發現各類好玩的js庫,不定期更新。如果你對前端的理解還是寫寫頁面綁綁事件,那你真的是有點OUT了,前端能做的事情已經太多了, , , , , , 甚至 ,什麼火就搞什麼,活脫脫一個 蹭熱點小能手 。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...