vue2.6.10+vite2開啟template模板動態(tài)編譯的過程
在從vue-cli遷移到vite2的時候,之前在代碼中使用的模板編譯遇到了問題:
我在項目中會根據(jù)后臺返回的內(nèi)容動態(tài)渲染,如果返回內(nèi)容中有<el-image>等標簽,v-html無法識別非html標簽,導致圖片渲染失敗,因此希望通過模板編譯的方式,將字符串傳遞給template字段,進行渲染。
代碼如下:
<!-- 用來渲染元素的組件 --> <script lang="jsx"> import Vue from 'vue' export default { name: 'renderContent', props: { html: String, elImage: Boolean, // 是否把圖片處理成el-image }, data () { return { } }, components: { }, computed: { }, render(h) { let htmlString = this.html || '' if(this.elImage === true) { // 把res中的updateDesc中的image處理成el-image // 匹配img的表達式 let reg1 = new RegExp(/<img [^>]*src=['"]([^'"]+)[^>]*>/gi); if(htmlString) { htmlString = htmlString.replace(reg1, function (match, capture) { return `<el-image src="${capture}" style="max-width: 100%;" fit="contain" :preview-src-list="['${capture}']"></el-image>` }); } } // 進行xss過濾 htmlString = this.$utils.xssFilter(htmlString) const com = Vue.extend({ template: `<div>${htmlString}</div>` }) return h(com, {}) } } </script>
此時會遇到報錯:
在vue-cli中,可以通過在vue.config.js中進行配置,解決此問題:
module.exports = { ..., runtimeCompiler: true, }
在vite中,我沒有找到類似于vue-cli中直接進行配置的方法,經(jīng)過參考后,發(fā)現(xiàn)可以通過以下方法解決:在vite.config.js中進行配置(直接貼我的解決辦法):
export default defineConfig({ resolve: { alias: { ..., "vue": "vue/dist/vue.common.prod.js", }, }, })
因為vite默認使用的vue是runtime-only的,所以通過聲明使用其他版本的vue來解決(具體vue 文件的名稱根據(jù)版本有差別,我使用的版本是vue2.6.10)
各個版本的大小和功能略有差異,大家選擇自己合適的就行。
其他的解決方案:使用web-component 自定義<el-image>
節(jié)點等。
參考文章:
Vue 能否實現(xiàn)動態(tài)編譯template模板?
到此這篇關于vue2.6.10+vite2開啟template模板動態(tài)編譯的文章就介紹到這了,更多相關vue開啟template模板動態(tài)編譯內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Vue3中關于getCurrentInstance的大坑及解決
這篇文章主要介紹了Vue3中關于getCurrentInstance的大坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04