您好,登錄后才能下訂單哦!
這篇文章主要介紹了Vue中的常用指令有哪些的相關(guān)知識,內(nèi)容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Vue中的常用指令有哪些文章都會有所收獲,下面我們一起來看看吧。
首先來聊聊Vue框架,Vue是一套用于構(gòu)建用戶界面的漸進式的JavaScript框架,對于初學者來說是非常友好的 , Vue的虛擬Dom , 數(shù)據(jù)雙向綁定 , 都使開發(fā)者可以快速上手 , 而我個人感覺 , Vue的指令使用起來非常的方便 , 今天的這篇文章們就來聊聊常用的Vue指令吧!
在初學任何一門語言的時候我們或多或少都接觸過 for
for (let i = 0; i < arr.length; i++) { }
Vue 的 v-for跟我們js里面的最根本的概念還是一樣的就是兩個字 循環(huán)
v-for后面括號里面 item 和 index 就相當for循環(huán)里面的 arr[i] 和 i 也就是對應(yīng)的每一個 元素 和 下標 , 后面的 in arr 這個 arr 就是我們想要循環(huán)的數(shù)組 最后一個 :key="item.id "是v-for的核心 如果沒有這個:key 我們的Vue就會報錯 , 那么為什么會有Key , Key要給的參數(shù)是什么呢? Key的參數(shù)是唯一的 , 也就是我們不管循環(huán)幾次 , 每次循環(huán)的key不能有重復(fù) , 這里我們不推薦用index來當你的Key , 說到底,key的作用就是更新組件時判斷兩個節(jié)點是否相同。相同就復(fù)用,不相同就刪除舊的創(chuàng)建新的。在渲染簡單的無狀態(tài)組件時,如果不添加key組件默認都是就地復(fù)用,不會刪除添加節(jié)點,只是改變列表項中的文本值,要知道節(jié)點操作是十分耗費性能的。而添加了key之后,當對比內(nèi)容不一致時,就會認為是兩個節(jié)點,會先刪除掉舊節(jié)點,然后添加新節(jié)點。
<li v-for="(item,index) in arr" :key="item.id"> {{ item.name }} </li>
v-show 是根據(jù)布爾值來進行渲染 , true 就頁面顯示 , false 就不在頁面顯示 ,他的原理其實是控制css樣式來使得我們對應(yīng)的組件或者盒子顯示 ,隱藏dispaly:"none"
,顯示dispaly:"block"
<div v-show="true"> 我 dispaly:"block" 拉 </div> <div v-show="false"> 我 dispaly:"none" 拉 </div> //假裝我隱藏了 你看不見我
v-if 也是根據(jù)布爾值來進行渲染 ,跟v-show也是差不多, true 就頁面顯示 , false 就不在頁面顯示 但是v-if是惰性的 如果初始值是false組件就不會渲染出來 , 知道第一次他的參數(shù)變成true 他才會渲染,但他的條件又變成false的時候 , 子組件適當就會唄地被銷毀和重建 , 如果需要非常頻繁地切換,則使用 v-show 較好;如果在運行時條件很少改變,則使用 v-if 較好。
<div v-if="true"> </div> <div v-if="false"> 我被銷毀了嗚嗚嗚 </div> //假裝我隱藏了 你看不見我
提到 v-if 也就聊到了 v-else 在 v-if條件不成立的時候就會直接走到v-else上去 ,記住v-else后面不能跟等號 , 組件之前必須要跟v-if
<div v-if="false"> 你看不到我啊 </div> //因為我條件不成立 <div v-else> 你能看到我 </div>
提到 v-if 和 v-else 也就也會想到 v-else-if 在 v-if條件不成立的時候就會直接走到v-else-if上去看條件判斷成立不成立 , 條件成立就渲染組件 , 組件之前必須要跟v-if
<p v-if="score>=90">厲害</p> <p v-else-if="score>=60">差不多</p>
v-once 它的作用就是定義它的元素或組件只會渲染一次 , 當?shù)谝淮武秩局笠膊粫S著數(shù)據(jù)的更新而來進行重新渲染 , 就相當于一個靜態(tài)內(nèi)容
<template> <div v-once>{{count}}</div> <button v-on:click="addCount"> 你點我count也不加 </button> </template> <script> export default { data() { return { count: 10 } }, methods: { addCount: function () { this.count += 1; console.log('this.count:'+this.count); } } } </script>
v-text 以文本的方式來插入數(shù)據(jù) , 是用于操作純文本 , 他是會替代本身元素上面的內(nèi)容,如果數(shù)據(jù)更新隨之試圖也會發(fā)生改變
<p v-text="data"> 你好你好 </p>
v-html v-html用于輸出html,它與v-text區(qū)別在于v-text輸出的是純文本,瀏覽器不會對其再進行html解析,但v-html會將其當html標簽解析后輸出
<p v-html="data">厲害</p> 頁面顯示:<p> <h2>你好啊<h2> </p> // 外層還是會有p標簽來包裹 data:<h2>你好啊<h2>
v-on 有一個簡便的寫法就是" @ " 簡單來說v-on就是綁定事件 , 可以在一個標簽綁定多個事件 , v-on:第一個是事件 , 事件后面跟著一個自定義方法
<button v-on:mouseenter='onenter' @click='leave'>click me</button>
v-bind 也有一個簡便的寫法就是" : " 簡單來說v-on就是用于綁定數(shù)據(jù)和元素屬性 , 最常用的方法就是用于動態(tài)綁定class
<ul :class="classObject"></ul>
v-model是Vue雙向綁定指令 , 它可以在頁面是輸入的狀態(tài)同時改變綁定data屬性 , 也會在data屬性發(fā)生改變的時候也更新頁面的狀態(tài) , 我們經(jīng)常在input上面能發(fā)現(xiàn)他的存在 , 他的本質(zhì)上其實是綁定了<input :value="test" @input="test = $event.target.value">
, v-model后面可以跟修飾符比如 .lazy 、.trim 和 .number 這些修飾符一起使用
.lazy 將input的實時更新改為一個change事件 , 只有失焦的時候input才會觸發(fā)事件
.trim 去除字符串首尾的空格
.number 將數(shù)據(jù)轉(zhuǎn)化為值類型
<input v-model="test"> <input v-model.lazy="msg" > <input v-model.trim="msg"> <input v-model.number="age" type="number">
關(guān)于“Vue中的常用指令有哪些”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“Vue中的常用指令有哪些”知識都有一定的了解,大家如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。