vue2.6.10+vite2开启template模板动态编译的过程

 更新时间:2023年02月03日 10:22:12   作者:yang1067155909  
这篇文章主要介绍了vue2.6.10+vite2开启template模板动态编译,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

在从vue-cli迁移到vite2的时候,之前在代码中使用的模板编译遇到了问题:

我在项目中会根据后台返回的内容动态渲染,如果返回内容中有<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中直接进行配置的方法,经过参考后,发现可以通过以下方法解决:在vite.config.js中进行配置(直接贴我的解决办法):

export default defineConfig({
    resolve: {
        alias: {
          ...,
          "vue": "vue/dist/vue.common.prod.js", 
        },
      },
})

因为vite默认使用的vue是runtime-only的,所以通过声明使用其他版本的vue来解决(具体vue 文件的名称根据版本有差别,我使用的版本是vue2.6.10)

各个版本的大小和功能略有差异,大家选择自己合适的就行。

其他的解决方案:使用web-component 自定义<el-image> 节点等。

参考文章:

Vue 能否实现动态编译template模板?

Vue隐藏技能——运行时渲染

到此这篇关于vue2.6.10+vite2开启template模板动态编译的文章就介绍到这了,更多相关vue开启template模板动态编译内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue父子组件之间事件通信示例解析

    Vue父子组件之间事件通信示例解析

    这篇文章主要介绍了React中父子组件通信详解,在父组件中,为子组件添加属性数据,即可实现父组件向子组件通信,文章通过围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2023-03-03
  • Vue实现简易购物车案例

    Vue实现简易购物车案例

    这篇文章主要为大家详细介绍了Vue实现简易购物车案例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-06-06
  • vue.js实现含搜索的多种复选框(附源码)

    vue.js实现含搜索的多种复选框(附源码)

    这篇文章主要给大家介绍了利用vue.js实现含搜索的多种复选框的相关资料,文中给出了简单的介绍,但提供了完整的实例源码供大家下载学习,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-03-03
  • Vue3中关于getCurrentInstance的大坑及解决

    Vue3中关于getCurrentInstance的大坑及解决

    这篇文章主要介绍了Vue3中关于getCurrentInstance的大坑及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • .html页面引入vue并使用公共组件方式

    .html页面引入vue并使用公共组件方式

    这篇文章主要介绍了.html页面引入vue并使用公共组件方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • 使用vue3+TS实现简易组件库的全过程

    使用vue3+TS实现简易组件库的全过程

    当市面上主流的组件库不能满足我们业务需求的时候,那么我们就有必要开发一套属于自己团队的组件库,下面这篇文章主要给大家介绍了如何使用vue3+TS实现简易组件库的相关资料,需要的朋友可以参考下
    2022-03-03
  • vue项目多租户环境变量的设置

    vue项目多租户环境变量的设置

    本文主要介绍了vue项目多租户环境变量的设置,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • Vue路由切换和Axios接口取消重复请求详解

    Vue路由切换和Axios接口取消重复请求详解

    在web项目开发的过程中,经常会遇到客服端重复发送请求的场景,下面这篇文章主要给大家介绍了关于Vue路由切换和Axios接口取消重复请求的相关资料,需要的朋友可以参考下
    2022-05-05
  • @error函数vue图片加载失败空白页解决方案

    @error函数vue图片加载失败空白页解决方案

    这篇文章主要介绍了@error函数vue图片加载失败空白页解决方案,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • 手写实现Vue计算属性

    手写实现Vue计算属性

    这篇文章主要介绍了手写实现Vue计算属性,本文从一个简单的计算属性例子开始,一步步实现了计算属性。并且针对这个例子,详细分析了页面渲染时的整个代码执行逻辑,需要的小伙伴可以参考一下
    2022-08-08

最新评论