vue?注釋template中組件的屬性說明
注釋template中組件屬性
想注釋一個(gè)組件的屬性,一直報(bào)錯(cuò)
[vue/no-parsing-error] Parsing error: unexpected-character-in-attribute-name
因?yàn)轫?xiàng)目中引入了eslint-plugin-vue,對(duì)template有默認(rèn)檢測,因此就直接修改.eslintrc.js文件
"unexpected-character-in-attribute-name": false,
發(fā)現(xiàn)也沒啥用.
最后一番查找發(fā)現(xiàn),這個(gè)插件是修改了VsCode的默認(rèn)配置
你得打開Vscode的配置文件
Ctrl+Shift+P ,輸入open workspace settings
再搜索 vetur.validation.template
把這玩意給設(shè)置成false就成(取消勾選項(xiàng))
實(shí)例中的template講解
代碼
//別忘了引包 <body> <div id="app-1"> {{msg}} </div> ================ <div id="app-2"> {{msg}} </div> ================= <div id="app-3"> {{msg}} </div> <script> //在vue.js中,可以使用template給元素添加模板,但是元素中只能有一個(gè)根元素,不能出現(xiàn)兩個(gè)或兩個(gè)以上的根同級(jí)元素。還可以在模板中綁定數(shù)據(jù)、表達(dá)式等。下面利用實(shí)例說明如何添加模板 // 創(chuàng)建 Vue 實(shí)例,得到 ViewModel new Vue({ el: '#app-1', data: { msg:'這是通過el屬性獲取掛載元素的outerHTML方式渲染' } }); //結(jié)論:如果vue實(shí)例中有template屬性,會(huì)將該屬性值進(jìn)行編譯,將編譯后的虛擬dom直接替換掉vue實(shí)例綁定的元素(即el綁定的那個(gè)元素); //注意:template屬性中的dom結(jié)構(gòu)只能有一個(gè)根元素,如果有多個(gè)根元素需要使用v-if、v-else、v-else-if設(shè)置成只顯示其中一個(gè)根元素; new Vue({ el: '#app-2', data: { msg:'這是通過el屬性獲取掛載元素的outerHTML方式渲染' }, template:'<div>這是template屬性模板渲染</div>' }); //render new Vue({ el: '#app-3', data: { msg:'這是通過el屬性獲取掛載元素的outerHTML方式渲染' }, template:'<div>這是template屬性模板渲染</div>', render: function(createElement){ return createElement('div', // 參數(shù)2、這里相當(dāng)于給標(biāo)簽加屬性 例如:<div style='color:red,font-size: 14px'></div> { //給div綁定樣式 style:{ width:'300px', height:'400px', color:'pink' }, //給div綁定點(diǎn)擊事件 on: { click: () => { console.log('點(diǎn)擊事件') } } }, // 參數(shù)3、參數(shù)中渲染的標(biāo)簽的子元素?cái)?shù)組(可選) // [ // // 文本節(jié)點(diǎn)直接寫就可以 // 'text' // ] '這是render屬性方式渲染。' ); } }); </script> </body>
調(diào)試圖片
原理說明圖片
終極結(jié)論
el,template,render屬性優(yōu)先性
當(dāng)Vue選項(xiàng)對(duì)象中有render渲染函數(shù)時(shí),Vue構(gòu)造函數(shù)將直接使用渲染函數(shù)渲染DOM樹,當(dāng)選項(xiàng)對(duì)象中沒有render渲染函數(shù)時(shí),Vue構(gòu)造函數(shù)首先通過將template模板編譯生成渲染函數(shù),然后再渲染DOM樹,而當(dāng)Vue選項(xiàng)對(duì)象中既沒有render渲染函數(shù),也沒有template模板時(shí),會(huì)通過el屬性獲取掛載元素的outerHTML來作為模板,并編譯生成渲染函數(shù)。
換言之,在進(jìn)行DOM樹的渲染時(shí),render渲染函數(shù)的優(yōu)先級(jí)最高,template次之且需編譯成渲染函數(shù),而掛載點(diǎn)el屬性對(duì)應(yīng)的元素若存在,則在前兩者均不存在時(shí),其outerHTML才會(huì)用于編譯與渲染。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue+element-ui JYAdmin后臺(tái)管理系統(tǒng)模板解析
這篇文章主要介紹了vue+element-ui JYAdmin后臺(tái)管理系統(tǒng)模板解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07Vue實(shí)現(xiàn)搖一搖功能(兼容ios13.3以上)
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)搖一搖功能,兼容ios13.3以上,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-01-01Vue3使用Proxy實(shí)現(xiàn)數(shù)據(jù)監(jiān)聽的原因分析
在本篇文章里小編給大家整理的是一篇關(guān)于Vue3使用Proxy實(shí)現(xiàn)數(shù)據(jù)監(jiān)聽的原因分析內(nèi)容,有需要的朋友們可以跟著學(xué)習(xí)參考下。2021-11-11詳解使用vue-admin-template的優(yōu)化歷程
這篇文章主要介紹了詳解使用vue-admin-template的優(yōu)化歷程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05vue菜單欄聯(lián)動(dòng)內(nèi)容頁面tab的實(shí)現(xiàn)示例
本文主要介紹了vue菜單欄聯(lián)動(dòng)內(nèi)容頁面tab的實(shí)現(xiàn)示例,左側(cè)菜單欄與右側(cè)內(nèi)容部分聯(lián)動(dòng),當(dāng)點(diǎn)擊左側(cè)的菜單,右側(cè)會(huì)展示對(duì)應(yīng)的tab,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01vue 輸入電話號(hào)碼自動(dòng)按3-4-4分割功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue 輸入電話號(hào)碼自動(dòng)按3-4-4分割功能的實(shí)現(xiàn)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04Vue中select下拉框的默認(rèn)選中項(xiàng)的三種情況解讀
這篇文章主要介紹了Vue中select下拉框的默認(rèn)選中項(xiàng)的三種情況解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05