」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 為什麼在 AngularJS 中使用“controller as”語法?

為什麼在 AngularJS 中使用“controller as”語法?

發佈於2024-11-19
瀏覽:917

Why Use \

理解AngularJS的“controller as”語法

簡介

AngularJS引入了定義控制器的新語法“controller as”,這引起了一些關注關於其目的的問題。本文旨在闡明此語法背後的基本原則及其優點。

Controller as 語法

「controller as」語法可讓您實例化控制器並將其指派給目前的變數範圍。例如:

controller('InvoiceController as invoice')

此程式碼告訴 Angular 建立 InvoiceController 的實例並將其儲存在目前範圍內的 Invoice 變數中。

從控制器中刪除 $scope

與「controller as」語法的一個顯著區別是它從控制器中刪除了 $scope 參數控制器定義。這允許更乾淨、更簡潔的控制器:

// With $scope
function InvoiceController($scope) {
  // Do something with $scope.qty
}

// With controller as
function InvoiceController() {
  // Do something with this.qty
}

在視圖中分配別名

雖然從控制器中刪除$scope可以簡化程式碼,但它要求您在視圖中指定別名:

// With $scope


// With controller as

控制器作為語法的用途

引入「controller as」語法主要是出於以下原因:

  • 刪除$scope: 一些開發人員更喜歡避免使用$scope 語法,認為它會混淆$scope 的來源properties.
  • 屬性來源的清晰度: 透過在視圖中使用別名,可以清楚哪些屬性屬於哪個控制器。這在嵌套控制器時特別有用。
  • 避免點規則問題:「controller as」語法有助於避免 AngularJS 的「點規則」問題,這可能會導致存取屬性變得困難來自父控制器。它允許對控制器​​屬性進行清晰且分層的存取。
最新教學 更多>
  • 為什麼 Goroutine 在 Windows 上有時會執行失敗?
    為什麼 Goroutine 在 Windows 上有時會執行失敗?
    理解 Windows 上非功能性 Goroutines 之謎在並發領域,Goroutines 在 Go 中充當輕量級線程。然而,一些程式設計師遇到了意想不到的挑戰:goroutines 無法在 Windows 上執行。為了解開這個謎團,讓我們深入研究根本問題。 根本原因:非同步執行與傳統執行緒不同,...
    程式設計 發佈於2024-11-19
  • ## JavaScript 可以偵測瀏覽器歷史記錄的可用性嗎?
    ## JavaScript 可以偵測瀏覽器歷史記錄的可用性嗎?
    如何偵測瀏覽器歷史記錄可用性確定瀏覽器中的後退按鈕是否可用是 Web 開發過程中常見的問題。然而,需要注意的是,使用 JavaScript 直接檢查瀏覽器歷史記錄通常是不可能實現的。 技術方法:history.previous技術上,一種方法是利用History.previous 屬性。該屬性應該指...
    程式設計 發佈於2024-11-19
  • 如何新增查詢字串來取得 GET 請求?
    如何新增查詢字串來取得 GET 請求?
    使用 Fetch GET 請求的查詢字串Fetch API 提供了一種在 JavaScript 中發出 HTTP 請求的現代方法。預設情況下,使用 Fetch 發出的 GET 請求不包含查詢字串參數。要將查詢字串新增至 GET 請求,我們可以使用 URLSearchParams 介面或手動連接查詢字...
    程式設計 發佈於2024-11-19
  • 為什麼在選擇子集時應該始終複製 Pandas DataFrame?
    為什麼在選擇子集時應該始終複製 Pandas DataFrame?
    了解Pandas 中資料幀複製的重要性在Pandas 中,選擇資料幀的一部分時,通常的做法是使用'.copy() ' 方法建立原始資料幀的副本。此方法可確保子集所做的任何變更都不會影響父資料框。 為什麼要複製? 預設情況下,索引資料框會傳回原始資料框的視圖,而不是副本。這意味著對子集...
    程式設計 發佈於2024-11-19
  • 為什麼在 C++ 中 `std::remove` 會重新排列元素而不是刪除它們?
    為什麼在 C++ 中 `std::remove` 會重新排列元素而不是刪除它們?
    理解差異:擦除與刪除在C 程式設計領域,std::erase 和std::remove 是兩個在修改容器時,不同的功能有不同的用途。雖然這兩個函數都可用於從容器中刪除元素,但它們的行為有所不同。 Std::remove:重新排列元素與刪除Std::刪除是一種對一系列元素進行操作並在容器內重新排列它們...
    程式設計 發佈於2024-11-19
  • 我可以依靠 PHP 的「php.ini」精度來進行準確的資金計算嗎?
    我可以依靠 PHP 的「php.ini」精度來進行準確的資金計算嗎?
    我可以依靠 PHP php.ini 精確度解決方案來解決浮點問題嗎? 簡介浮點運算是一個經常被誤解的複雜主題,它遍布現代電腦系統。由於大多數小數缺乏精確的二進位表示,因此不可避免地會發生舍入。了解浮點運算的細微差別至關重要,如「每個電腦科學家應該了解的浮點算術知識」所述。 問題與解答問題1:我可以使...
    程式設計 發佈於2024-11-19
  • 委託如何增強 C++ 程式碼的靈活性和可維護性?
    委託如何增強 C++ 程式碼的靈活性和可維護性?
    解釋 C 中委託的通用概念 C 中的委託是一種程式設計結構,可讓您將函數指標作為參數傳遞。這使您能夠創建可以非同步調用或在不同上下文中調用的回調。 在C 中實作委託有多種方法,包括:函子函子是物件定義了一個operator()函數,有效地使它們可調用。 struct Functor { in...
    程式設計 發佈於2024-11-19
  • 如何在 Java 中建立動態命名物件?
    如何在 Java 中建立動態命名物件?
    使用字串派生變數名稱動態建立物件當嘗試使用動態產生的名稱建立物件時,Java 嚴格的變數命名規則可能看起來很有限。然而,這種明顯的限制實際上是 Java 關注變數引用以及變數名稱的重要性相對減弱的結果。 雖然 PHP 等腳本語言允許創建具有字串派生名稱的變量,但 Java 採用了不同的方法。 Jav...
    程式設計 發佈於2024-11-19
  • 你應該在 JavaScript 中使用自增和自減運算子嗎?
    你應該在 JavaScript 中使用自增和自減運算子嗎?
    JavaScript 中增量和減量運算符的爭議jslint 工具警告不要使用增量( ) 和減量(-- )運營商出於各種原因。然而,反對這些運算符的論點有些爭議。 反對 and 的論點 --jslint 工具特別指出,and -- 鼓勵「過度狡猾」和已知會導致安全漏洞。此外,PHP 構造 $foo[$...
    程式設計 發佈於2024-11-19
  • 如何使用 Python 從網站中提取每日日出/日落時間?
    如何使用 Python 從網站中提取每日日出/日落時間?
    使用Python 進行網頁抓取使用Python 進行網頁抓取使用Python 從網站擷取每日日出/日落時間問:使用Python 從網站擷取每日日出/日落時間您確實可以利用Python 的強大功能來抓取網頁內容並從網站中提取日出/日落時間等資料。 Python 提供了一套全面的模組來促進網頁抓取。讓我...
    程式設計 發佈於2024-11-19
  • 為什麼不能直接在 Go 中使用有類型約束的介面?
    為什麼不能直接在 Go 中使用有類型約束的介面?
    介面類型約束在開發 Go 應用程式時,了解介面類型約束所施加的限制至關重要。具有類型元素的介面類型(例如聯合)的使用受到限制。本文深入研究了介面類型約束的細節,並提供了範例來說明其影響。 使用類型約束定義介面在 Go 中,包含型別元素(例如聯合)的介面被考慮非基本。這意味著它們不能用作變數的類型或作...
    程式設計 發佈於2024-11-19
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-19
  • 如何使用Python在Linux下截圖?
    如何使用Python在Linux下截圖?
    在Linux 上使用Python 輕鬆截取螢幕截圖對於那些尋求透過Python 腳本輕鬆捕捉螢幕截圖的便捷方法的人來說,本指南提供了專為Linux 環境設計的有效解決方案。 Pythonic 螢幕截圖大師為了實現這種截圖能力,Python 利用了它與X Window 系統交互的能力,X Window...
    程式設計 發佈於2024-11-19
  • 如何使用 jQuery 即時動態更改 CSS 類別規則?
    如何使用 jQuery 即時動態更改 CSS 類別規則?
    使用 jQuery 動態更改 CSS 類別規則您的查詢涉及兩個方面:1。即時修改類別規則僅靠 jQuery 無法動態變更 CSS 類別規則。但是,您可以利用文件物件的 styleSheets 屬性直接存取 CSS 規則。 代號:document.getElementById("button...
    程式設計 發佈於2024-11-19
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-11-19

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3