亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Angularjs 基礎入門

2019-11-20 13:36:03
字體:
來源:轉載
供稿:網友

針對于這個其實我不太清楚應該針對于哪些人或者說不知道從哪開始寫,所以這里我就按照一種簡單的思路開始寫

1.angular.element
2.angular.Bootstrap

我們非常清楚ng-app應用到節點,angular自動幫你初始化,初始化的過程分為如下幾個步驟

1.angular會在document load的時候自動初始化,首先會找到ng-app這個指令指定的節點。
2.加載與module相關的指令
3.創建與應用相關的injector(依賴管理器)
4.以制定的ng-app為根節點,開始對Dom進行compile

現在我們自己初始化一下,做一個等同于ng-app這個指令的東西。angular.element這個就是包裝,包裝原始DOM元素或HTML字符串作為jQuery元素。angular.Bootstrap可以手動初始化腳本,我們用這兩個來初始化這個腳本

復制代碼 代碼如下:

<!DOCTYPE HTML>
  <html lang="zh-cn">
  <head>
  <meta charset="UTF-8">
  <title>Bootstrap-manual</title>
  <style type="text/css">
  .ng-cloak {
  display: none;
  }
  </style>
  </head>
  <body>
  這里是ng-app外面的~~{{1+2}}
  <div id="widuu" >這里是ng-app里面~~~ {{1+2}}</div>
  <script src="angular.min.js" type="text/javascript"></script>
  <script type="text/javascript">
  angular.element(document).ready(function() {
  angular.bootstrap(angular.element(document.getElementById("widuu")));
  });
  </script>
  </body>
  </html>

2.compiler

我們清楚的看到angularjs的官方文檔上邊都是駝峰式命名法,譬如ngApp、ngModule、ngBind等等這些都是相關的指令,其中html compiler就是允許我們自己定義元素 屬性和標簽,Angular將這些附加行為稱為directives。
官方文檔對compiler的解釋是這樣的

復制代碼 代碼如下:

Compiler
  Compiler is an Angular service which traverses the DOM looking for attributes. The compilation process happens in two phases.

  Compile: traverse the DOM and collect all of the directives. The result is a linking function.

  Link: combine the directives with a scope and produce a live view. Any changes in the scope model are reflected in the view, and any user interactions with the view are reflected in the scope model. This makes the scope model the single source of truth.

  Some directives such as ng-repeat clone DOM elements once for each item in a collection. Having a compile and link phase improves performance since the cloned template only needs to be compiled once, and then linked once for each clone instance.

compiler是angular的一個(service),負責遍歷dom節點和查找屬性,編譯分為兩個階段:

1.編譯:遍歷節點和收集所有的directives,返回一個鏈接函數linking function
2.鏈接:將directives綁定到一個作用域(scope)中,創建一個實況視圖(live view)。在scope中的任何改變,將會在視圖中得到體現(更新視圖);任何用戶對模版的活動(改變),將會體現在scope model中(雙向綁定)。這使得scope model能夠反映正確的值。
一些directives,諸如ng-repeat,會為每一個在集合(collection)中的元素復制一次特定的元素(組合)。編譯和鏈接兩個階段,使性能得以提升。因為克隆出來的模版(template)只需要編譯一次,然后為每一個集合中的元素進行一次鏈接(類似模版緩存)。

3.一步一步創建自己的directive

1.了解directive
首先了解,directive是按照駝峰式命名法,如ngModule,當編譯的時候匹配是這樣的,舉例如下:

復制代碼 代碼如下:

<input ng-model="foo">
  <input data-ng:model="foo">
 

directive可以使用x-或者data-作為前綴,可以使用:, -, 或者 _等分隔符來轉換駝峰式命名方法,如下所示:

復制代碼 代碼如下:

<span ng-bind="name"></span> <br/>
  <span ng:bind="name"></span> <br/>
  <span ng_bind="name"></span> <br/>
  <span data-ng-bind="name"></span> <br/>
  <span x-ng-bind="name"></span> <br/>

一般我們使用ng-bind對應ngBind,這種格式
$compile可以匹配directive基于元素名稱,屬性,類名以及注釋

復制代碼 代碼如下:

<my-dir></my-dir>
  <span my-dir="exp"></span>
  <!-- directive: my-dir exp -->
  <span class="my-dir: exp;"></span>

 在編譯過程中,compiler通過$interpolate服務匹配文本與屬性中的嵌入表達式(如{{something}})。這些表達式將會注冊為watches,并且作為digest cycle的一部分,一同更新。下面是一個簡單的interpolation:
<img src="img/{{username}}.jpg"/>Hello {{username}}!
  
2.編譯的步驟

HTML“編譯”的三個步驟:

1. 首先,通過瀏覽器的標準API,將HTML轉換為DOM對象。這是很重要的一步。因為模版必須是可解析(符合規范)的HTML。這里可以跟大多數的模版系統做對比,它們一般是基于字符串的,而不是基于DOM元素的。
2. 對DOM的編譯(compilation)是通過調用$comple()方法完成的。這個方法遍歷DOM,對directive進行匹配。如果匹配成功,那么它將與對應的DOM一起,加入到directive列表中。只要所有與指定DOM關聯的directive被識別出來,他們將按照優先級排序,并按照這個順序執行他們的compile() 函數。directive的編譯函數(compile function),擁有一個修改DOM結構的機會,并負責產生link() function的解析。$compile()方法返回一個組合的linking function,是所有directive自身的compile function返回的linking function的集合。
3. 通過上一步返回的linking function,將模版與scope連接起來。這反過來會調用directive自身的linking function,允許它們在元素上注冊一些監聽器(listener),以及與scope一起建立一些watches。這樣得出的結果,是在scope與DOM之間的一個雙向、即時的綁定。scope發生改變時,DOM會得到對應的響應。

復制代碼 代碼如下:

var $compile = ...; // injected into your code
  var scope = ...;
  var html = '<div ng-bind='exp'></div>';
  // Step 1: parse HTML into DOM element
  var template = angular.element(html);
  // Step 2: compile the template
  var linkFn = $compile(template);
  // Step 3: link the compiled template with the scope.
  linkFn(scope);

ngAttr屬性綁定

復制代碼 代碼如下:

<svg>
  <circle ng-attr-cx="{{cx}}"></circle>
  </svg>

今天就寫到這里,明天開始寫創建directive ~~~控制篇幅不要太長,這章主要概念的多~~~

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲福利视频专区| 欧美午夜久久久| 97在线观看视频国产| 欧美多人乱p欧美4p久久| 亚洲精品aⅴ中文字幕乱码| 欧洲日韩成人av| 欧美激情视频一区二区| 2019中文字幕在线观看| 国产精品久久久久久av福利软件| 欧美理论电影在线播放| 日韩欧美一区二区在线| 在线电影欧美日韩一区二区私密| 91精品91久久久久久| 中文字幕日韩欧美在线| 日韩在线免费视频观看| 国产精品久久电影观看| 日韩电影在线观看永久视频免费网站| 久久久久久久久综合| 国产精品色婷婷视频| 成人国产亚洲精品a区天堂华泰| 亚洲国产又黄又爽女人高潮的| 91精品视频在线免费观看| 欧美精品激情blacked18| 国产精品美女免费看| 成人性生交xxxxx网站| 亚洲精品www久久久| 国产精品亚洲аv天堂网| 日韩成人黄色av| 亚洲精品动漫100p| 国产精品爽爽ⅴa在线观看| 在线成人免费网站| 成人免费网站在线观看| 久久香蕉国产线看观看网| 久久久免费在线观看| 久久精品国产成人| 51视频国产精品一区二区| 欧美美女15p| 日韩成人激情在线| 日韩国产一区三区| 91在线观看欧美日韩| 国产精品91在线观看| 欧美日韩国产999| 久久99国产综合精品女同| 91在线观看欧美日韩| 97av在线影院| 欧美日韩亚洲视频| 国产不卡在线观看| 日韩精品久久久久久福利| 国产在线视频91| 国产亚洲精品激情久久| 亚洲一区二区三区777| 高清一区二区三区四区五区| 久久99久久亚洲国产| 国内精品一区二区三区四区| 久久精品中文字幕电影| 88国产精品欧美一区二区三区| 亚洲欧洲免费视频| 日本免费一区二区三区视频观看| 欧美电影在线观看完整版| 欧美日韩国产一中文字不卡| 尤物九九久久国产精品的分类| 中文字幕亚洲专区| 欧美刺激性大交免费视频| 红桃视频成人在线观看| 亚洲精品久久久久久久久久久久| 亚洲春色另类小说| 久久亚洲一区二区三区四区五区高| 韩国国内大量揄拍精品视频| 久久精品国产96久久久香蕉| 欧美精品福利视频| 亚洲丝袜av一区| 欧美日韩激情小视频| 欧美激情aaaa| 亚洲高清免费观看高清完整版| 欧美一级在线亚洲天堂| 欧美亚洲另类在线| 久久99精品久久久久久琪琪| 国产主播欧美精品| 国产精品激情av电影在线观看| 91美女福利视频高清| 国产第一区电影| 国产精品香蕉国产| 午夜欧美大片免费观看| 一本久久综合亚洲鲁鲁| 中文字幕日韩欧美在线| 欧美成人免费小视频| 2018日韩中文字幕| 91九色单男在线观看| 亚洲人成网站在线播| 精品国产一区二区三区久久久狼| 欧美一性一乱一交一视频| 九九热最新视频//这里只有精品| 国产精品久久久久久久久久久久| 日韩一区二区精品视频| 国产一区二区香蕉| 国产欧美日韩最新| 色999日韩欧美国产| 亚洲精品国产精品国自产在线| 91av在线网站| 亚洲毛茸茸少妇高潮呻吟| 亚洲欧洲午夜一线一品| 日韩视频免费大全中文字幕| 日韩欧美一区二区三区| 亚洲精品456在线播放狼人| 亚洲最大的网站| 亚洲欧美激情在线视频| 日韩成人在线观看| 免费99精品国产自在在线| 亚洲综合国产精品| 欧美成人一二三| 成人欧美一区二区三区在线湿哒哒| 国产精品18久久久久久麻辣| 91麻豆国产语对白在线观看| 国产精品黄色av| 亚洲人成电影网站色xx| 亚洲欧美国产一本综合首页| 91精品91久久久久久| 欧美激情极品视频| 成人h猎奇视频网站| 黄色成人在线播放| 一区二区三区视频在线| 国产亚洲精品激情久久| 在线观看国产欧美| 久久这里只有精品视频首页| 久久久久久午夜| 久久精品91久久香蕉加勒比| 91免费综合在线| 国产中文字幕亚洲| 亚洲国产日韩欧美在线动漫| 国产精品成人免费电影| 国产精品久久久久国产a级| 日韩网站免费观看| 在线观看日韩www视频免费| 78m国产成人精品视频| 一区二区三区视频免费在线观看| 亚洲激情电影中文字幕| 国内精品中文字幕| 国产精品91视频| 国产精品久久综合av爱欲tv| 精品国产一区二区三区四区在线观看| 久色乳综合思思在线视频| 欧美综合在线第二页| 亚洲激情视频在线观看| 欧美日韩一区二区在线播放| 国产亚洲精品一区二区| 久久综合久久八八| 欧美激情videoshd| 亚洲视频综合网| 久久久国产精彩视频美女艺术照福利| 国产精品精品视频| 亚洲精品suv精品一区二区| 一区二区三区视频免费在线观看| 欧美一区二区三区图| 亚洲精品99久久久久中文字幕| 97久久精品在线| 国产精品福利无圣光在线一区| 欧美成人亚洲成人| 91久久国产精品| 亚洲男女自偷自拍图片另类| 青青草99啪国产免费| 欧美猛男性生活免费| 久99久在线视频| 久久精品国产亚洲| 亚洲男人天天操|