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

首頁 > 編程 > JavaScript > 正文

KnockoutJs快速入門教程

2019-11-20 10:02:41
字體:
來源:轉載
供稿:網友

一、引言

之前這個系列文章已經介紹Bootstrap,詳情請查看本文: 《Bootstrap入門教程》 ,由于最近項目中,前端是Asp.net MVC + KnockoutJs + Bootstrap來做的。所以我又重新開始寫這個系列。今天就讓我們來看看Web前端的MVVM框架――KnockoutJs。

二、KnockoutJs是什么?

做.NET開發的人應該都知道,WPF中就集成了MVVM框架,所以KnockoutJs也是針對Web開發的MVVM框架。關于MVVM好處簡單點來說就是――使得業務邏輯代碼與頁面展示代碼分割開,使得前端項目更好維護。

之前,我們寫Web頁面的時候,JS代碼和Html代碼混合在一起,并且代碼中充斥著大量的DOM對象的操作。這樣代碼結構非?;靵y。有了MVVM框架了,你可以將JS代碼和Html代碼分割開,并且數據操作部分更加簡單,只需要通過相應的語法(data-bind)綁定到對應的標簽屬性顯示即可,從而加快開發速度。

KnockoutJs也就是這樣一個MVVM框架。其實與其稱其框架,更準備地應該是一個MVVM類庫。因為它沒有MVVM框架是一個比較“重”的概念,其中應該包括路由等特性。而KnockoutJS中卻沒有,相比較,AngularJS應該稱為一個MVVM框架更加合適。

KnockoutJS主要實現的功能有以下4點:

聲明式綁定(Declarative Bindings):使用簡單的語法將模型數據關聯到DOM元素上。即"data-bind"語法
依賴跟蹤(Dependency Tracking):為轉變和聯合數據,在模型數據之間建立關系。如商品總價是由各個商品項價格之和。此時商品總價和商品項就可以使用依賴跟蹤功能來建立關系。即由各個商品項的總價相加而得出。這種關系由KnockoutJs中computed函數完成。
UI界面自動刷新(Automatic UI Refresh):當你的模型狀態改變時,UI界面的將自動更新。這點由observable函數完成。
模板(Templating):為您的模型數據快速編寫復雜的可嵌套UI。和WPF中模板的概念類似。
接下來,我們通過具體的例子來讓大家快速掌握KnockoutJs的使用。

三、聲明式綁定
下面讓我們看下如何使用KnockoutJS中的data-bind語法來將模型數據綁定到DOM元素中。

1.單向綁定

<!DOCTYPE html><html><head> <meta name="viewport" content="width=device-width" /> <title>Demo1-單向綁定</title> <script type="text/javascript" src="/uploads/rs/376/pbcx3e1z/knockout-3.4.0.js"></script></head> <body>  <!--單向綁定-->  <div>   <p>First name: <strong data-bind="text: firstName"></strong></p>   <p>Last name: <strong data-bind="text: lastName"></strong></p>   <p>First name: <input data-bind="value: firstName" /></p>   <p>Last name: <input data-bind="value: lastName" /></p>  </div>   <!--這段腳本實際項目中應該放在對應的JS文件中,然后在html中通過Script標簽來引用即可-->  <!--JS代碼也就是業務邏輯部分,將業務邏輯與Html代碼分割開,使得View代碼更加簡潔,這樣后期也易于維護-->  <script type="text/javascript">   function ViewModel() {    this.firstName = "Tommy";    this.lastName = "Li";   }   ko.applyBindings(new ViewModel());  </script> </body></html>

2. 上面的例子只是完成了單向綁定的操作。即在上面的例子你會發現,當改變input標簽中的值并離開焦點時,上面的值不會更新。其實,KnockoutJS中自動更新功能不會自動添加的,需要對應的函數支持,這個函數就是observable函數,下面具體看看雙向綁定的例子:

<!DOCTYPE html><html><head> <meta name="viewport" content="width=device-width" /> <title>Demo2-雙向綁定</title>  <script type="text/javascript" src="/uploads/rs/376/pbcx3e1z/knockout-3.4.0.js"></script></head><body> <!--雙向綁定--> <div>  <p>First name: <strong data-bind="text: firstName"></strong></p>  <p>Last name: <strong data-bind="text: lastName"></strong></p>  <p>First name: <input data-bind="value: firstName"/></p>  <p>Last name: <input data-bind="value: lastName" /></p> </div> <script type="text/javascript">  function ViewModel() {   this.firstName = ko.observable("Tommy");   this.lastName = ko.observable("Li");  }    ko.applyBindings(new ViewModel()); </script></body></html>

四、依賴跟蹤
接下來讓我們看下如何使用KO中的computed函數來完成依賴跟蹤。具體例子的實現代碼如下所示:

<!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>Demo3-依賴跟蹤</title>  <script type="text/javascript" src="/uploads/rs/376/pbcx3e1z/knockout-3.4.0.js"></script></head><body> <!--雙向綁定--> <div>  <p>First name: <strong data-bind="text: firstName"></strong></p>  <p>Last name: <strong data-bind="text: lastName"></strong></p>  <p>First name: <input data-bind="value: firstName" /></p>  <p>Last name: <input data-bind="value: lastName"/></p>  <p>Full name: <strong data-bind="text: fullName"></strong></p>  <button data-bind="click: capitalizeLastName">LastName To Upper</button> </div> <script type="text/javascript">  function ViewModel() {   this.firstName = ko.observable("Tommy");   this.lastName = ko.observable("Li");   // 依賴跟蹤   this.fullName = ko.computed(function () {    return this.firstName() + " " + this.lastName();   },this);      // 通過代碼改變observable的值   this.capitalizeLastName = function() {    this.lastName(this.lastName().toUpperCase());   };  }  ko.applyBindings(new ViewModel()); </script></body></html>

接下來,讓我們看一下使用聲明式綁定和依賴跟蹤復雜點的例子。具體示例代碼如下:

<!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>Demo4-列表綁定</title>  <script type="text/javascript" src="http://sandbox.runjs.cn/uploads/rs/376/pbcx3e1z/knockout-3.4.0.js"></script></head><body> <table>  <thead>   <tr>    <td>Name</td>    <td>Amount</td>    <td>Price</td>   </tr>  </thead>  <tbody data-bind="foreach: items">   <tr>    <td data-bind="text: product.name"></td>    <td><select data-bind="options:[1,2,3,4,5,6],value: amount"></select></td>    <td data-bind="text: subTotal"></td>    <td><a href="#" data-bind="click: $root.remove">Remove</a></td>   </tr>  </tbody> </table> <h3>Order Price: <span data-bind="text: price"></span></h3> <button data-bind="click: addComputer">Add a Computer</button> <script type="text/javascript">  var products = [{ name: "Learnighard 學習筆記", price: 49 },  { name: "小米Note", price: 999 },   { name: "宏亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

中文字幕日韩视频| 亚洲视频第一页| 成人av在线天堂| 国产精品欧美在线| 亚洲第一男人天堂| 日韩av在线网站| 欧美成人精品xxx| 亚洲激情 国产| 热门国产精品亚洲第一区在线| 国内成人精品视频| 久久精品免费电影| 国产亚洲欧美一区| 91av国产在线| 亚洲大胆人体在线| 日韩欧美aⅴ综合网站发布| 日韩中文字幕免费| 亚洲欧美成人一区二区在线电影| 68精品国产免费久久久久久婷婷| 国产亚洲欧美日韩精品| 久久精品国产欧美亚洲人人爽| 91av在线网站| 欧美视频中文在线看| 中文字幕亚洲综合久久筱田步美| 最新中文字幕亚洲| 欧美日韩久久久久| 日本在线精品视频| 亚洲国产成人久久综合| 欧美国产视频日韩| 久久亚洲一区二区三区四区五区高| 日韩美女免费线视频| 久久久www成人免费精品| 亚洲欧美国产视频| 91精品国产高清自在线| 久久久久久噜噜噜久久久精品| 亚洲一区二区久久久| 最近2019中文字幕在线高清| 成人a在线视频| 欧美性xxxx18| 8x海外华人永久免费日韩内陆视频| 激情久久av一区av二区av三区| 欧美性极品xxxx娇小| 日本免费久久高清视频| 中文字幕欧美日韩精品| 国产欧美韩国高清| 亚洲电影中文字幕| 国产视频精品xxxx| 国产亚洲激情视频在线| 亚洲国产精品yw在线观看| 精品成人国产在线观看男人呻吟| 欧洲亚洲女同hd| 国产ts一区二区| 成人免费网站在线观看| 中文字幕亚洲激情| 欧美国产日韩免费| 国产脚交av在线一区二区| 欧美日韩国产91| 久久亚洲春色中文字幕| 欧美日韩成人免费| 第一福利永久视频精品| 中文字幕国内精品| 日韩高清免费在线| 久久综合国产精品台湾中文娱乐网| 欧美视频一区二区三区…| 精品视频在线播放| 国产亚洲人成网站在线观看| 成人欧美在线观看| www.日韩欧美| 国产精品久久77777| 久久精品国产免费观看| 亚洲人成欧美中文字幕| 色青青草原桃花久久综合| 欧美激情按摩在线| 久久久精品网站| 久久精品国产精品亚洲| 亚洲欧美在线播放| 国产精品1区2区在线观看| 亚洲国内高清视频| 久久久久国产精品www| 亚洲码在线观看| 久久影院模特热| 少妇高潮久久久久久潘金莲| 久久91亚洲精品中文字幕| 日韩精品中文字幕在线播放| 欧美日韩中国免费专区在线看| 91免费看片在线| 亚洲精品中文字幕av| 欧美孕妇性xx| 精品国模在线视频| 日韩免费在线免费观看| 国产视频观看一区| 一区二区三区天堂av| 92国产精品久久久久首页| 97国产精品人人爽人人做| 国产亚洲aⅴaaaaaa毛片| 久久久综合av| 亚洲区免费影片| 国产欧美精品xxxx另类| 国产精品日韩欧美综合| 亚洲bt天天射| 欧美巨猛xxxx猛交黑人97人| 成人激情视频在线播放| 国产精品色午夜在线观看| 国产精品亚洲自拍| 日本高清不卡的在线| 91国内精品久久| 91po在线观看91精品国产性色| 精品久久久久久久久中文字幕| 亚洲精品视频在线观看视频| 国产成人精品久久二区二区| 中文字幕日韩专区| 久久久噜噜噜久久| 色老头一区二区三区| 欧美激情视频给我| 91av免费观看91av精品在线| 久久久久成人网| 在线国产精品播放| 欧美成人合集magnet| 亚洲综合最新在线| 欧美亚洲日本网站| 国产91免费观看| 亚洲аv电影天堂网| 日韩极品精品视频免费观看| 在线视频中文亚洲| 国产成人精品999| 亚洲国产小视频| 日本精品久久久久久久| 日韩欧中文字幕| 日韩精品极品视频| 日韩精品在线免费播放| 日本亚洲精品在线观看| 欧美美女操人视频| 久久久久这里只有精品| 亚洲国产精品悠悠久久琪琪| 欧美专区在线视频| 色婷婷综合成人| 久久精品99久久久久久久久| 欧美精品成人91久久久久久久| 亚洲第一网中文字幕| 国产日本欧美一区| 日韩午夜在线视频| 色悠悠久久久久| 亚洲丁香婷深爱综合| 欧美视频在线观看免费网址| 久久精品中文字幕免费mv| 国产精品久久久久久久久男| 欧美激情精品久久久久久久变态| 欧美另类交人妖| 亚洲自拍偷拍色图| 亚洲第一福利网| 欧美成人精品在线观看| 日本精品免费一区二区三区| 国产成人精品久久二区二区91| 久久人人爽人人| 欧美日韩在线观看视频| 日韩中文字幕第一页| 理论片在线不卡免费观看| 91在线无精精品一区二区| 久久久噜久噜久久综合| 亚洲国产精品va在线| 国产精品视频一区二区高潮| 亚洲第一视频网| 日韩欧美亚洲成人| 尤物tv国产一区| 国产日韩在线精品av|