vue1.x升级vue2.x,使用字符串模板,页面无法渲染

问题详情

  1. 项目中原使用vue1.x,现升级到2.x

  2. 如图,项目中使用.html文件,并在js文件中引入该文件,使用template字符串渲染vue模板

    arduino 复制代码
    // index.js
    import template from './index.html'
    export default {
        template: template,
        data() {
            ...
        },
        ...
    }

在vue1.x中项目可正常运行,升级至vue2.x,页面无法渲染

问题分析

vue不同构建版本

vue1.x 不区分运行时和完整版,vue2.x默认使用运行时版本

完整版包含运行时+编译器,编译器作用:将模板字符串编译成js渲染函数

图片来源:vue2官网

模板编译

模板字符串编译

模板字符串解析需要编译器,所以需要引入完整版vue

图片来源:vue2官网

vm.$mount

完整版和运行时的区别在于是否有模板编译阶段,其主要表现在vm.$mount方法的实现上。

只包含运行时版本的mount方法获取到DOM后直接进入挂载阶段。而完整版的mount中先进行模板编译,编译成渲染函数;再回过头调用(与只包含运行时版本相同的)$mount,进入挂载阶段。

详见: Vue源码系列-Vue中文社区

vue-loader预编译

运行时版本不包含模板编译阶段,配合vue-loader进行预编译。vue-loader对.vue文件中的<template>预编译成渲染函数。所以不存在模板编译阶段,运行时版可由初始化直接进入挂载阶段。

预编译优势

很明显,编译过程对性能造成损耗,生产环境引入编译也增大了代码体积。所以预编译提高了运行时的性能,vue运行时版本减少了生产环境代码。

解决方案

webpack配置别名(使用模板字符串编译器)

配置来源:vue2官网

java 复制代码
module.exports = {
  // ...
  resolve: {
    alias: {
      'vue$': 'vue/dist/vue.esm.js' // 用 webpack 1 时需用 'vue/dist/vue.common.js'
    }
  }
}

vue cli配置runtimeCompiler(使用模板字符串编译器)

图片来源:vue cli 官网

推荐

不使用模板字符串写法,改为<template>

相关推荐
敏姐的后花园36 分钟前
模考倒计时网页版
java·服务器·前端
AiXed2 小时前
PC微信WDA算法
前端·javascript·macos
一只小阿乐7 小时前
react 封装弹框组件 传递数据
前端·javascript·react.js
533_7 小时前
[element-plus] el-tree 动态增加节点,删除节点
前端·javascript·vue.js
禁止摆烂_才浅7 小时前
前端开发小技巧-【JavaScript】- 获取元素距离 document 顶部的距离
前端·javascript·react.js
wshzd7 小时前
LLM之Agent(二十九)|LangChain 1.0核心组件介绍
前端·javascript·langchain
程序猿_极客7 小时前
Vue 2脚手架从入门到实战核心知识点全解析(day6):从工程结构到高级通信(附代码讲解)
前端·javascript·vue.js·vue2学习笔记
q***71858 小时前
海康威视摄像头ISUP(原EHOME协议) 摄像头实时预览springboot 版本java实现,并可以在浏览器vue前端播放(附带源码)
java·前端·spring boot
web加加8 小时前
vue3 +vite项目页面防f12,防打开控制台
前端·javascript·vue.js
A尘埃9 小时前
大模型应用python+Java后端+Vue前端的整合
java·前端·python