AngularJS中監視Scope變數以及外部調用Scope方法

来源:http://www.cnblogs.com/darrenji/archive/2016/01/23/5152959.html
-Advertisement-
Play Games

在AngularJS中,有時候需要監視Scope中的某個變數,因為變數的改變會影響一些界面元素的顯示。有時,也希望通過jQuery調用Scope的某個方法。比如以下場景: jQ Button Toggle jQ button state Counter: {{counter}}以...


 

在AngularJS中,有時候需要監視Scope中的某個變數,因為變數的改變會影響一些界面元素的顯示。有時,也希望通過jQuery調用Scope的某個方法。

比如以下場景:

 

<div>
    <button id="jQBtn">jQ Button</button>
</div>

<div id="ngSection" ng-controller="NGCtrl">
    <input type="checkbox" ng-model="jQBtnState"/> Toggle jQ button state
    <p>Counter: {{counter}}</p>
</div>

 

以上,我們希望:

● Scope中的jQBtnState變數值如果為false讓id為jQBtn的按鈕禁用
● 點擊id為jQBtn的按鈕調用Scope中的某個方法讓Scope中的變數counter自增1

我們可能會這樣寫:

 

$('#jQBtn').on("click", function(){
    console.log("JQuery button clicked");
    
    //需要考慮的問題是:
    //這裡如何調用Scope中的某個方法,使Scope的的變數counter自增1
})


...

myApp.controller("NGCtrl", function($scope){
    $scope.counter = 0;
    
    //這裡,怎麼讓jQBtnState變數值發生變化告之外界呢?
    $scope.jQBtnState = false;
    
    $scope.jQBtnClick = function(){
        $scope.counter++;
    }
})

 

其實,使用$watch方法可以監視Scope某個變數的變化,當變化發生調用回調函數。

 

myApp.controller("NGCtrl", function($scope){
    $scope.counter = 0;
    $scope.jQBtnState = false;
    
    $scope.$watch("jQBtnState", function(newVal){
        $('#jQBtn').attr('disabled', newVal);
    });
    
    $scope.jQBtnClick = function(){
        $scope.counter++;
    }
})

 

以上,當jQBtnState變數值為false的時候就會禁用id為jQBtn的按鈕。

外界如何調用Scope的方法呢?

--先獲取Scope,然後使用$apply方法調用Scope內的方法

 

$('#jQBtn').on("click", function(){
    console.log("JQuery button clicked");
    var scope = angular.element(ngSection).scope();
    scope.$apply(function(){
        scope.jQBtnClick();
    });
})

 

以上,通過獲取Scope,使用$apply方法調用Scope內的jQBtnClick方法使Scope呢的變數counter自增1。

 


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

-Advertisement-
Play Games
更多相關文章
  • APP全棧式開發概要
  • 因為公司的項目用到是slim 框架,所以想把它學習一下。在公司用到是Slim2版本,現在官網已經到達 Slim3的版本了。官網地址:http://www.cnblogs.com/lmenglliren89php/。 首先按照官網的教程,安裝Slim: 1.curl -sS https:/...
  • <h2 CSS 偽元素 (Pseudo elements)實例</h2 <h3 CSS 實例</h3 CSS 背景實例 CSS 文本實例 CSS 字體(font)實例 CSS 邊框(border)實例 CSS 外邊距 (margin) 實例 CSS 內邊距 (padding) 實例 CSS 列表實....
  • 下麵,我們給大家提供了一個用於HTML5開發的各種用途的JavaScript庫列表。這些框架能夠給前端開發人員提供更好的功能實現的解決方案。如果你有收藏優秀的框架,也可以在後面的評論中分享給我們。1.EasyStar.js如果構建HTML5游戲或其他互動內容,那麼一定要檢查outEasyStar.j...
  • <h2 CSS 偽類 (Pseudo classes) 實例</h2 <h3 CSS 實例</h3 CSS 背景實例 CSS 文本實例 CSS 字體(font)實例 CSS 邊框(border)實例 CSS 外邊距 (margin) 實例 CSS 內邊距 (padding) 實例 CSS 列表實例....
  • 一.highcharts簡介以及引入 highcharts作為免費提供給個人學習、個人網站和非商業用途使用的前端圖表演示插件的確使用起來十分方便和輕便。在我最近完成一個需求的時候用到了它, 它的相容性也很強,其在標準(W3C標準)瀏覽器中使用SVG技術渲染圖形,在遺留的IE瀏覽器中使用VML技術來....
  • Form Plugin API 里提供了很多有用的方法可以讓你輕鬆的處理表單里的數據和表單的提交過程。測試環境:部署到Tomcat中的web項目。一、引入依賴js 二、初始化回調函數。首先,我們初始化這個表單,給它一個beforeSubmit回調函數 - 這是一個用來校驗的函數。$(docum...
  • JS中處理相容的方式總結:1、使用try、catch來處理相容 ->原理:在try中讓JS代碼執行,如果執行過程中報錯了,說明不相容,我們在catch中用其他的方式來實現我們的相容處理 ->前提:不相容的情況下執行報錯才可以 ->弊端:不管當前的瀏覽器是否相容,都要先把try中的代碼執行一遍,...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...