Vue项目打包后内联字符串不显示的原因

1.问题描述

以下代码是使用vue语法写得一个字符串模板。运行没问题,但打包后却不显示。

javascript 复制代码
// template是一个字符串
const CustomNode = {
  props: ["data"],
  template: `
    <div class="custom-node" :class="'status-' + data.status">
      <div class="node-name">{{ data.nodeName }}</div>
      <div class="node-status">{{ data.permissionFlag }}</div>
    </div>
  `
};

2.原因解析

CustomNode 使用了内联字符串模板,在生产构建时缺少 Vue 的模板编译器 ,导致节点无法渲染。
本地开发时 ,Vue 使用的是完整版(包含模板编译器),所以字符串模板 template: '...' 能正常工作。
打包构建时,为了减小体积,默认使用运行时版(不含编译器),此时 template 字符串无法被编译成渲染函数,自定义节点渲染失败,只剩下边和箭头。

若通过打包配置(保留模板编译器),会增加打包体积**(不建议)**,如下。

javascript 复制代码
export default defineConfig({
  resolve: {
    alias: {
      'vue': 'vue/dist/vue.esm-bundler.js'  // 使用完整版
    }
  }
})

3.修改:

以下是通过渲染函数进行渲染,或将其封装成组件也可。这样就解决问题了

javascript 复制代码
// h是vue中的渲染函数
const CustomNode = {
  props: ["data"],
  setup(props) {
    return () =>
      h("div", { class: `custom-node status-${props.data.status}` }, [
        h("div", { class: "node-name" }, props.data.nodeName),
        h("div", { class: "node-status" }, props.data.permissionFlag)
      ]);
  }
};
相关推荐
JoyGqz34 分钟前
Vue 2 EOL 之后还在跑生产?这个开源安全分支已修主流 CVE,一行依赖即可接入
vue.js
zz58835 分钟前
面试官问"JS的类型"时,到底想听到什么?
javascript
gjwjuejin37 分钟前
全埋点技术方案深度剖析:从事件代理到无痕采集的完整实现
javascript
十有八七44 分钟前
AI 开发,本质是一场文档的生命周期管理
前端·人工智能
Lkstar1 小时前
Vue 3 Composition API 进阶:自定义 Hooks 与 provide/inject 的高级玩法
vue.js·面试
Hyyy1 小时前
普通前端自救记录——第0周
前端
前端若水2 小时前
在 Vue 2 与 Vue 3 中使用 markdown-it-vue 渲染 Markdown 和数学公式
前端·javascript·vue.js
之歆2 小时前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(下)
开发语言·前端·javascript·ecmascript
Aolith2 小时前
用 Vue 递归组件实现嵌套回复,我的评论系统升级全记录
vue.js·全栈
行星飞行2 小时前
从 cursor 、 Claude code 迁移到 codex,30 分钟快速上手 codex 常用技巧
前端