前端框架之Angular(二)

来源:http://www.cnblogs.com/miaomiaowuwu/archive/2016/12/19/6197199.html
-Advertisement-
Play Games

這節主要說一下Angular的指令。Angular的指令有內置指令和自定義指令。 一、內置指令 在 Angular 中通過指令對DOM的功能進行擴展。這也是對常用功能的模塊化封裝。Angular 提供了一系列常用的指令,這些指定都是以 ng 開頭的,我們稱為內置指令。 後面會講到如何自定義指令。其實 ...


 

這節主要說一下Angular的指令。Angular的指令有內置指令和自定義指令。

一、內置指令

在 Angular 中通過指令對DOM的功能進行擴展。這也是對常用功能的模塊化封裝。Angular 提供了一系列常用的指令,這些指定都是以 ng 開頭的,我們稱為內置指令。

後面會講到如何自定義指令。其實內置指令和自定義指令是沒有區別的,只是angular已經幫我們定義好了。

預設指令有如下幾種常用的:

  • ng-app 啟用一個模塊
  • ng-model 雙向綁定數據
  • ng-init 直接初始化生成一個 scope
  • ng-controller 調用 controller
  • ng-click 綁定click事件
  • ng-href
  • ng-src
  • ng-disabled
  • ng-checked
  • ng-readonly
  • ng-selected
  • ng-class
  • ng-style

以 ng-click 為例,這樣使用:

 <div ng-click=“onClick()”></div>

二、自定義指令(directive)

我們完全可以只依賴angular內置的指令,以及自己寫的各種 controller 來完成一個應用。但是這樣就無法復用一些通用的視圖邏輯。

在 Angular 中,通過指令來拓展DOM元素的功能。我們可以把通用的邏輯封裝成指令,在不同的地方都可以調用這些指令。比如我們可以把 分頁器封裝成一個指令,使用分頁器的時候就不需要寫複雜的邏輯,只要像下麵這樣指定幾個參數即可:

 <div pagination page-total=‘100’ page-current=’20’></div>

這樣就會調用 pagination 指令自動生成一個分頁器,並通過兩個屬性告訴它總頁數是100,當前是第20頁。

那麼我們這樣編寫指令:

.directive("pagination", function() {
    return {
      restrict: "EA",
      template:
        "<div>\
          <button ng-click='prev()' ng-disabled='!hasPrev()'>prev</button>\
          <span>{{current}}</span>\
          <button ng-click='next()' ng-disabled='!hasNext()'>next</button>\
        <div>",
      replace: true,
      scope: {
        total: "@pageTotal",
        current: "@pageCurrent"
      },
      link: function($scope) {
        $scope.total = parseInt($scope.total);
        $scope.current = parseInt($scope.current);
        $scope.prev = function() {
          $scope.current --;
        }
        $scope.next = function() {
          $scope.current ++;
        }
        $scope.hasNext = function() {
          return $scope.current < $scope.total;
        }
        $scope.hasPrev = function() {
          return $scope.current > 0;
        }
      }
    }
  })

其中, 我們定義了一個 pagination 指令,返回的一個對象描述了這個指令的全部定義。我們一點一點看:

restrict: “EA”表示這個指令可以通過元素名或者屬性名的方式來使用,可選值有“EAC”三種,分別是Element,Attribute 和 Class 的縮寫。

template 表示這個指令對應的模板,結合下麵的replace: true會直接講使用此指令的dom換成對應的模板。

scope是一個JSON對象,表示為這個指令創建了一個隔離的作用域,其中通過@語法把 DOM 中的屬性複製到scope對象中。

link是一個鏈接函數,一般我們指令中的邏輯代碼寫在鏈接函數中。當Angular完成模塊編譯和數據綁定之後,會調用link函數進行鏈接。這裡我們定義了四個函數,用來進行頁面跳轉動作和跳轉條件的判斷。

看完這個分頁器指令基本就能知道一個指令的基本組成,一般一個指令的最重要部分就是模板、作用域和鏈接函數。如果你在這個模板上聲明瞭一個 controller ,那麼這裡的作用域其實就是 controller的作用域。不過由於angular限制一個DOM上只能綁定一個隔離作用域,所以這裡如果聲明瞭一個controller,則無法再在 指令中聲明隔離作用域。

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 前言 在EFCore中執行Sql語句的方法為:FromSql與ExecuteSqlCommand;在EF6中的為SqlQuery與ExecuteSqlCommand,而FromSql和SqlQuery有很大區別,FromSql返回值為IQueryable,因此為延遲載入的,可以與Linq擴展方法配合 ...
  • 使用阿裡大於API發送簡訊,但阿裡沒有提供NetCore 的API,自己看了下源碼重寫了發簡訊這個部分 public class MessageSender { private readonly string _appKey; private readonly string _appSecret; ...
  • 什麼是負載均衡 負載均衡(Load Balance)是分散式系統架構設計中必須考慮的因素之一,它通常是指,將請求/數據【均勻】分攤到多個操作單元上執行,負載均衡的關鍵在於【均勻】。 常見的負載均衡方案 常見互聯網分散式架構如上,分為客戶端層、反向代理nginx層、站點層、服務層、數據層。可以看到,每 ...
  • 回到目錄 什麼是LindAspects 之前寫了關於Aspects的文章《Lind.DDD.Aspects通過Plugins實現方法的動態攔截~Lind里的AOP》,今天主要在設計思想上進行刨析一下,對緩存攔截器一直沒有實現,所以文章了也一直沒有發出來,讓大家等這麼久實在不好意思。LindAspec ...
  • 一、概述 橋接模式:將兩個原本不相關的類結合在一起,然後利用兩個類中的方法和屬性,輸出一份新的結果。 二、案例 1、模擬毛筆(轉) 需求:現在需要準備三種粗細(大中小),並且有五種顏色的比 如果使用蠟筆,我們需要準備3*5=15支蠟筆,也就是說必須準備15個具體的蠟筆類。而如果使用毛筆的話,只需要3 ...
  • 第一是:項目的路徑需要放在Documents and Settings\,也就是預設的文件夾的地方,不然會報錯錯誤範例為:Question:CY8CKIT-023 kit example project fails to build in PSoC Creator with the followin ...
  • 我使用的是海康DS-2CD852MF-E, 200萬,網路攝像機,已經比較老了,不過SDK在海康官網下載的,開發流程都差不多. 海康攝像機回調解碼後的視頻數據格式為YV12,順便說一下YV12的數據格式 YYYY V U. 我這個是720P,即1280 * 720解析度. 那麼Y分量的數量為 128 ...
  • 適配器模式:將一個類的介面轉換成客戶希望的另外一個介面,使得原本由於介面不相容而不能一起工作的那些類可以在一起工作。 如下圖(借圖): // 設置書的介面 客戶端測試: 輸出結果: 這時候,你想創建一個可以復用的類,該類可以與其他不相關的類或不可預見的類(即那些介面可能不一定相容的類)協同工作。 如 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...