欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vuejs入門教程之Vue生命周期,數(shù)據(jù),手動掛載,指令,過濾器

 更新時間:2017年04月19日 10:43:52   作者:qq20004604  
本篇文章主要介紹了Vuejs入門教程之Vue生命周期,數(shù)據(jù),手動掛載,指令,過濾器的相關(guān)知識。具有很好的參考價值。下面跟著小編一起來看下吧

原教程:

http://cn.vuejs.org/guide/instance.html

http://cn.vuejs.org/guide/syntax.html

本博文是在原教程的基礎(chǔ)上加上實(shí)例,并嘗試說明的更詳細(xì)。

(十)Vue實(shí)例的生命周期

如圖:(我自己翻譯的中文版,英文版請查看本博文頂部的,第一個鏈接)

(八)傳入的數(shù)據(jù)綁定

先創(chuàng)建一個對象(假如是obj),然后將他傳入Vue實(shí)例中,作為data屬性的值,那么

①obj的值的變化,將影響Vue實(shí)例中的值的變化;

②相反一樣;

③可以在Vue實(shí)例外面操縱obj,一樣對Vue實(shí)例有影響;

④獲取obj.a的值(假如他有這個屬性),可以通過Vue實(shí)例(例如變量vm),vm.a這樣的形式來獲?。ㄋ麄兪堑葍r的,也是綁定的);

⑤后續(xù)添加的數(shù)值是無效的

例如:

<div id="app"> 
 {{a}} 
</div> 
<button onclick="add()">+1</button> 
<script> 
 var obj = {a: 1} 
 var vm = new Vue({ 
  el: '#app', 
  data: obj 
 }) 
 function add() { 
  //vm.a++; 
  obj.a++; 
 } 
</script> 

add函數(shù)中兩條語句效果是等價的,都可以讓顯示的值+1

但若將代碼改成這樣:

var obj = {b: 1} 
var vm = new Vue({ 
 el: '#app', 
 data: obj 
}) 
function add() { 
 obj.a = 1; 
} 

那么在點(diǎn)擊按鈕后,并不會顯示值(沒有綁定)。

注意:即使修改為vm.a=1也是無效的

準(zhǔn)確的說,在Vue實(shí)例創(chuàng)建后,添加新的屬性到實(shí)例上,是不會觸發(fā)視圖更新的。

在以上情況下,obj.a === vm.a ,注意,a之前沒有data。

函數(shù):

function test() { 
 if (vm.a === obj.a) { 
  console.log("vm.a === obj.a"); 
 } 
} 

其判斷條件是true

(九)Vue實(shí)例暴露的接口

在上一篇中,提到vm.a=obj.a這個;然而我們并沒有獲取全部的data這個屬性;

而Vue提供了幾個暴露的接口:

接口(假設(shè)實(shí)例為vm)   效果

vm.$data                 是vm的data屬性

vm.$el                     是vm的el屬性所指向的dom結(jié)點(diǎn)

vm.$watch               示例:

                                vm.$watch(“a”,function(newVal, oldVal){})

                                當(dāng)data里的a變化時,會觸發(fā)回調(diào)函數(shù)

更多的可以查看

http://cn.vuejs.org/api/

搜索 $ 作為關(guān)鍵詞來查看。

(十一)$mount()手動掛載

當(dāng)Vue實(shí)例沒有el屬性時,則該實(shí)例尚沒有掛載到某個dom中;

假如需要延遲掛載,可以在之后手動調(diào)用vm.$mount()方法來掛載。例如:

<div id="app"> 
 {{a}} 
</div> 
<button onclick="test()">掛載</button> 
<script> 
 var obj = {a: 1} 
 var vm = new Vue({ 
  data: obj 
 }) 
 function test() { 
  vm.$mount("#app"); 
 } 

初始,顯示的是{{a}}

當(dāng)點(diǎn)擊按鈕后,變成了1

(十二)用Vue的v-for寫一個表格

<!DOCTYPE html> 
<html> 
<head> 
 <title>Vue</title> 
 <script src="vue.js"></script> 
</head> 
<body> 
<div id="app"> 
 <button onclick="load()">點(diǎn)擊掛載表格</button> 
</div> 
<style> 
 table { 
  border-collapse: collapse; 
  border-spacing: 0; 
  border-left: 1px solid #888; 
  border-top: 1px solid #888; 
  background: #efefef; 
 } 

 th, td { 
  border-right: 1px solid #888; 
  border-bottom: 1px solid #888; 
  padding: 5px 15px; 
 } 

 th { 
  font-weight: bold; 
  background: #ccc; 
 } 
</style> 
<script> 
 var obj = { 
  grid: [ 
   {id: "ID", name: "名字", description: "描述", clickButton: "點(diǎn)擊事件"}, 
   {id: "1", name: "a", description: "amorous", clickButton: "點(diǎn)擊彈窗"}, 
   {id: "2", name: "b", description: "beautiful", clickButton: "點(diǎn)擊彈窗"}, 
   {id: "3", name: "c", description: "clever", clickButton: "點(diǎn)擊彈窗"}, 
   {id: "4", name: "d", description: "delicious", clickButton: "點(diǎn)擊彈窗"}, 
  ] 
 } 
 var vm = new Vue({ 
  data: obj, 
  template: '<table><tr v-for="row in grid">' + 
  '<td>{{row.id}}</td>' + 
  '<td>{{row.name}}</td>' + 
  '<td>{{row.description}}</td>' + 
  '<td><button v-on:click="alert($index)">{{row.clickButton}}</button></td>' + 
  '</tr></table>', 
  methods: { 
   alert: function (index) { 
    alert("該行是第" + index + "行") 
   } 
  } 
 }) 
 function load() { 
  vm.$mount("#app"); 
 } 
</script> 
</body> 
</html> 

(十三)數(shù)據(jù)綁定:

html標(biāo)簽的純文本顯示/被當(dāng)做html標(biāo)簽處理;

插值單次更新;

①使用兩個大括號時,假如字符串內(nèi)容是html標(biāo)簽,那么不會被轉(zhuǎn)義,而是正常顯示;

②使用三個打括號時,字符串內(nèi)的html標(biāo)簽會被直接轉(zhuǎn)義,

例如:

<div id="app"> 
 {{html}} 
</div> 
<script> 
 var vm = new Vue({ 
  el:"#app", 
  data: { 
   html:"<span>span</span>" 
  } 
 }) 
</script> 

屏幕上顯示內(nèi)容是:

<span>span</span> 

如果是三個大括號包含變量名:

<div id="app"> 
 {{{html}}} 
</div> 
<script> 
 var vm = new Vue({ 
  el:"#app", 
  data: { 
   html:"<span>span</span>" 
  } 
 }) 
</script> 
<script> 
 function load() { 
  vm.$mount("#app"); 
 } 
</script> 

顯示的內(nèi)容則只有

span

③插入內(nèi)容的數(shù)據(jù)綁定無效(在沒有使用partials的情況下)

使用兩個大括號或者三個大括號都一樣

例如,將②中的html改為以下值

data: { 
 html: "<span>span{{val}}</span>", 
 val: "11" 
} 

顯示結(jié)果乃是:

span{{val}}

說明沒有綁定數(shù)據(jù);

按照說明,使用partials可以綁定

http://cn.vuejs.org/api/#partial

不過不會用,等研究明白了再說

④禁止在用戶提交的內(nèi)容上動態(tài)渲染,否則會受到XSS攻擊

⑤插值也可以用在html標(biāo)簽的屬性中,例如class,或者id,或者其他。

但是Vue.js的指令和特殊特性內(nèi)是不可以用插值的。

(十四)綁定表達(dá)式

插值的位置,可以使用JavaScript的表達(dá)式,例如:

<div id="app"> 
 {{html?html:val}} 
</div> 
<script> 
 var vm = new Vue({ 
  el: "#app", 
  data: { 
   html: "", 
   val: "11" 
  } 
 }) 
</script> 

例如以上示例,

假如有html值,則輸出hmtl值,否則輸出val值;

也可以輸出字符串,例如改為:

{{html?html:"no words"}} 

則輸出no words

但是只能輸出表達(dá)式,不能輸出比如函數(shù),或者直接放個v-for標(biāo)簽之類的。

但是我推斷后者應(yīng)該可以,可能是我寫的方法不對。

(十五)過濾器

①簡單來說,在插值中,加入管道符“|”,然后過濾器會生效。

例如:

capitalize這個過濾器,會將字符串的首字母大寫

<div id="app"> 
 {{{html|capitalize}}} 
</div> 
<script> 
 var vm = new Vue({ 
  el: "#app", 
  data: { 
   html: "abc", 
   val: "11" 
  } 
 }) 
</script> 

輸出值是Abc

如果是漢字、數(shù)字、或者是本身首字母就大寫了,則無反應(yīng)。

②過濾器不能充當(dāng)表達(dá)式使用,因此不能在表達(dá)式內(nèi)使用過濾器,只能在表達(dá)式的后面使用。

例如:

{{html[0]|capitalize}}

是可以的,會輸出html的首個字母并將其大寫;

(html|capitalize)[0] 

是會報錯的(不加括號也報錯),說明,不能將過濾器視為表達(dá)式的一部分

③過濾器可以加參數(shù)。

第一個參數(shù):固定為表達(dá)式的值(被過濾目標(biāo));

第二個參數(shù),過濾器后面的第一個單詞;

第三個參數(shù),過濾器后面的第二個單詞,依次類推。

參數(shù)加引號則視為字符串,參數(shù)不加引號則視為表達(dá)式,表達(dá)式的值作為參數(shù)傳遞給過濾器。

官方例子是:

{{ message | filterA 'arg1' arg2 }}

④過濾器可以自己手寫

(十六)指令

①指令(Directives)就是特殊的,以帶有前綴v-的特性。

簡單粗暴來說,標(biāo)簽里v-開頭的就是指令(當(dāng)然,要Vue能支持)。

指令的值限定為 綁定表達(dá)式,就是等號后引號里的。

如:

<div id="app"> 
 <div v-if="html"> 
  {{val}} 
 </div> 
 <button onclick="test()">消失上一行</button> 
</div> 
<script> 
 var vm = new Vue({ 
  el: "#app", 
  data: { 
   html: "abc", 
   val: "11" 
  } 
 }) 
 function test() { 
  vm.html = ""; 
 } 
</script> 

輸出11

其中<div v-if=”html”>就是指令,

可以通過點(diǎn)擊按鈕讓那一行消失(因?yàn)閔tml的值被設(shè)置為空)

②指令后面可以添加參數(shù):

有些指令(例如v-bind)可以在名稱后等號前,添加一個屬性,這個屬性的作用是響應(yīng)性的更新HTML特性。

例如:

<style> 
 .white { 
  background-color: white; 
 } 
 
 .black { 
  background-color: black; 
 } 
</style> 
<div id="app"> 
 <div v-bind:class="BC">背景顏色變化</div> 
 <button onclick="test()">消失上一行</button> 
</div> 
<script> 
 var vm = new Vue({ 
  el: "#app", 
  data: { 
   BC: "black" 
  } 
 }) 
 function test() { 
  vm.BC = "white"; 
 } 
</script> 

初始情況下,這個div的class和data里的BC綁定,由于BC的值是black,那么相當(dāng)于v-bind所在的標(biāo)簽的class=”black”,所以初始情況下,背景顏色為黑色。

當(dāng)點(diǎn)擊按鈕后,BC的值被更改為white,那么相當(dāng)于標(biāo)簽的class=”white”,而類white的背景顏色為白色,所以該div的背景顏色變成了白色。

類似的有v-on:click事件,表示監(jiān)視的是click事件,也可以改為

<div v-on:mouseup="alert">背景顏色變化</div> 

表示該標(biāo)簽當(dāng)鼠標(biāo)彈起的時候,執(zhí)行methods的alert函數(shù)。

③修飾符

修飾符用于表示指令應(yīng)當(dāng)以特殊的方式進(jìn)行綁定。

例如:.literal修飾符告訴指令應(yīng)當(dāng)將他的值解析為字符串,而不是表達(dá)式

或者是keydown.enter表示按回車鍵時調(diào)用函數(shù)

<input v-on:keydown.enter="alert"></input> 

④縮寫:

v-on的縮寫是@ shift+數(shù)字2

v-bind的縮寫是:就是冒號

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

相關(guān)文章

  • Vue的filters(本地)或filter(全局)過濾常用數(shù)據(jù)類型解析

    Vue的filters(本地)或filter(全局)過濾常用數(shù)據(jù)類型解析

    這篇文章主要介紹了Vue的filters(本地)或filter(全局)過濾常用數(shù)據(jù)類型,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 詳解vue如何使用自定義指令

    詳解vue如何使用自定義指令

    在Vue的模板語法中,我們學(xué)了很多指令,當(dāng)然除了這些指令,Vue也允許我們自己定義自己的指令,所以本文就來和大家聊聊如何使用自定義指令吧
    2023-10-10
  • vite打包靜態(tài)文件打開顯示空白的解決

    vite打包靜態(tài)文件打開顯示空白的解決

    本文主要介紹了vite打包靜態(tài)文件打開顯示空白的解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • vue前端更新后需要清空緩存代碼示例

    vue前端更新后需要清空緩存代碼示例

    這篇文章主要給大家介紹了關(guān)于vue前端更新后需要清空緩存的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue具有一定的參考借鑒價值,需要的朋友可以參考下
    2024-10-10
  • Vue EventBus自定義組件事件傳遞

    Vue EventBus自定義組件事件傳遞

    這篇文章主要介紹了Vue EventBus自定義組件事件傳遞,組件化應(yīng)用構(gòu)建是Vue的特點(diǎn)之一,本文主要介紹EventBus進(jìn)行數(shù)據(jù)消息傳遞 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • vue實(shí)現(xiàn)tab標(biāo)簽(標(biāo)簽超出自動滾動)

    vue實(shí)現(xiàn)tab標(biāo)簽(標(biāo)簽超出自動滾動)

    當(dāng)創(chuàng)建的tab標(biāo)簽超出頁面可視區(qū)域時自動滾動一個tab標(biāo)簽距離,并可手動點(diǎn)擊滾動tab標(biāo)簽,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • vue router返回到指定的路由的場景分析

    vue router返回到指定的路由的場景分析

    這篇文章主要介紹了vue router返回到指定的路由的場景分析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • Vue slot插槽的使用詳情

    Vue slot插槽的使用詳情

    這篇文章主要介紹了Vue slot插槽的使用,在生活中很多地方都有插槽,電腦usb的插槽,插板當(dāng)中的電源插槽,插槽的目的是為了讓我們原來的設(shè)備具備更多的擴(kuò)展性比如電腦的USB我們可以插入U盤,手機(jī),鼠標(biāo),鍵盤等等,下面文章就來介紹Vue slot插槽是如何使用的
    2021-10-10
  • vue+elementUI面包屑組件封裝方法詳解

    vue+elementUI面包屑組件封裝方法詳解

    這篇文章主要為大家詳細(xì)介紹了vue+elementUI面包屑組件封裝方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Vue日期時間選擇器組件使用方法詳解

    Vue日期時間選擇器組件使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了Vue日期時間選擇器組件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08

最新評論