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

vue2.6.10+vite2開啟template模板動態(tài)編譯的過程

 更新時間:2023年02月03日 10:22:12   作者:yang1067155909  
這篇文章主要介紹了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模板?

Vue隱藏技能——運行時渲染

到此這篇關于vue2.6.10+vite2開啟template模板動態(tài)編譯的文章就介紹到這了,更多相關vue開啟template模板動態(tài)編譯內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue父子組件之間事件通信示例解析

    Vue父子組件之間事件通信示例解析

    這篇文章主要介紹了React中父子組件通信詳解,在父組件中,為子組件添加屬性數(shù)據(jù),即可實現(xiàn)父組件向子組件通信,文章通過圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2023-03-03
  • Vue實現(xiàn)簡易購物車案例

    Vue實現(xiàn)簡易購物車案例

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)簡易購物車案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • vue.js實現(xiàn)含搜索的多種復選框(附源碼)

    vue.js實現(xiàn)含搜索的多種復選框(附源碼)

    這篇文章主要給大家介紹了利用vue.js實現(xiàn)含搜索的多種復選框的相關資料,文中給出了簡單的介紹,但提供了完整的實例源碼供大家下載學習,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • Vue3中關于getCurrentInstance的大坑及解決

    Vue3中關于getCurrentInstance的大坑及解決

    這篇文章主要介紹了Vue3中關于getCurrentInstance的大坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • .html頁面引入vue并使用公共組件方式

    .html頁面引入vue并使用公共組件方式

    這篇文章主要介紹了.html頁面引入vue并使用公共組件方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 使用vue3+TS實現(xiàn)簡易組件庫的全過程

    使用vue3+TS實現(xiàn)簡易組件庫的全過程

    當市面上主流的組件庫不能滿足我們業(yè)務需求的時候,那么我們就有必要開發(fā)一套屬于自己團隊的組件庫,下面這篇文章主要給大家介紹了如何使用vue3+TS實現(xiàn)簡易組件庫的相關資料,需要的朋友可以參考下
    2022-03-03
  • vue項目多租戶環(huán)境變量的設置

    vue項目多租戶環(huán)境變量的設置

    本文主要介紹了vue項目多租戶環(huán)境變量的設置,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • Vue路由切換和Axios接口取消重復請求詳解

    Vue路由切換和Axios接口取消重復請求詳解

    在web項目開發(fā)的過程中,經(jīng)常會遇到客服端重復發(fā)送請求的場景,下面這篇文章主要給大家介紹了關于Vue路由切換和Axios接口取消重復請求的相關資料,需要的朋友可以參考下
    2022-05-05
  • @error函數(shù)vue圖片加載失敗空白頁解決方案

    @error函數(shù)vue圖片加載失敗空白頁解決方案

    這篇文章主要介紹了@error函數(shù)vue圖片加載失敗空白頁解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • 手寫實現(xiàn)Vue計算屬性

    手寫實現(xiàn)Vue計算屬性

    這篇文章主要介紹了手寫實現(xiàn)Vue計算屬性,本文從一個簡單的計算屬性例子開始,一步步實現(xiàn)了計算屬性。并且針對這個例子,詳細分析了頁面渲染時的整個代碼執(zhí)行邏輯,需要的小伙伴可以參考一下
    2022-08-08

最新評論