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)
      ]);
  }
};
相关推荐
Captaincc5 分钟前
置身钉内:一个 AI 办公产品的理想、失焦与组织困境
前端·程序员
零陵上将军_xdr14 分钟前
后端转全栈学习-Day6-JavaScript 基础-4
前端·javascript·学习
川冰ICE17 分钟前
JavaScript实战②|电商网站交互效果,轮播图与购物车
开发语言·javascript·交互
凌云拓界23 分钟前
状态机与思考循环 ——CogitoAgent开发实战(一)
javascript·人工智能·架构·node.js·设计规范
sugar__salt29 分钟前
Bun 新一代 JavaScript/TypeScript 运行时:从入门到实战
开发语言·javascript·typescript
梦幻通灵1 小时前
Vue3 Element日期控件置灰明天之后日期
前端·javascript·vue.js
lzhdim1 小时前
C盘空间多出来4GB:谷歌服软 Chrome本地AI大模型可禁用、删除了
前端·人工智能·chrome
Monkery1 小时前
WWDC26 全面汇总
前端·人工智能
ANnianStriver1 小时前
PetLumina 03 — 后端目录重构与 Web 管理后台搭建
java·前端·ai·重构·ai编程·claude code
晓13131 小时前
【Cocos Creator 3.x】篇——第一章 简介
前端·javascript·游戏引擎