前端框架之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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...