vue插值表達式和v-text指令的區別
{{message}}
語法隻能在標簽內容中使用
{{}}
這種語法叫做插值表達式,在插值表達式中可以寫任何合法的js表達式
1.使用插件表達式
使用插件表達式,存在內容閃爍問題,但是v-text沒有閃爍問題
<div id="app"> <p> {{message}} </p> <p v-text="message"></p> </div> <script src="./js/vue.js"></script>
<script> let vm = new Vue({ el:"#app", data:{ message:"hello vue" } }) </script>
在上面這段代碼中,如果正常輸出的話結果是一致的。
但是如果網速比較慢的話,插件表達式則會先在頁面上輸出
{{message}}
隨後才會正常渲染頁面,這樣的效果對用戶體驗是不夠好的。
2.在插件表達式中使用v-cloak解決閃爍問題
<style> [v-cloak]:{ display:none; } </style> <div id="app"> <p v-cloak> {{message}} </p> <p v-text="message"></p> </div> <script src="./js/vue.js"></script>
我們可以使用v-cloak
屬性在運行時讓其隱藏,但因為在運行結束時vue
會自動刪除v-cloak
屬性
所以可以用這種方法來解決閃爍問題
3.插件表達式
插件表達式隻會插入內容,不會覆蓋原本的內容,而v-text
會覆蓋掉原先的內容
<div id="app"> <p> ----{{message}}---- </p> // ----hello vue---- <p v-text="message">1234556</p> // hello vue </div> <script src="./js/vue.js"></script> <script> let vm = new Vue({ el:"#app", data:{ message:"hello vue" } }) </script>
到此這篇關於vue插值表達式和v-text指令的區別的文章就介紹到這瞭,更多相關vue插值表達式和v-text指令的區別內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Vue指令的學習
- 單頁面Vue頁面刷新出現閃爍問題及解決
- vue如何解決數據加載時,插值表達式閃爍問題
- Vue過濾器與內置指令和自定義指令及組件使用詳解
- Vue+thinkphp5.1+axios實現文件上傳