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)
      ]);
  }
};
相关推荐
Hyyy17 分钟前
Function Calling / Tool Use的原理和实现模式
前端·llm·ai编程
爱勇宝24 分钟前
从 Ctrl+CV 到 Enter:程序员正在失去什么
前端·后端·程序员
徐小夕42 分钟前
我们开源了一款“框架无关”的思维导图编辑器,3分钟集成到任意系统
前端·javascript·github
PBitW1 小时前
GPT训练我的第三天,明白了应该咋说满分回答!😕😕😕
前端·javascript·面试
像我这样帅的人丶你还1 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
摸着石头过河的石头1 小时前
前端多仓库管理:从混乱到有序的进化之路
前端
星栈1 小时前
写 Dioxus Demo 不难,难的是把它写成项目
前端·rust·前端框架
labixiong1 小时前
还原一个完整符合规范的 Promise(二)
前端·javascript
时光足迹2 小时前
腾讯云 TRTC UniApp SDK 从入门到上线
前端·vue.js·uni-app
时光足迹2 小时前
uni-app 里把加密视频嵌入页面播放?我分析了 4 种方案,只有 1 种接近完美
前端·vue.js·uni-app