解决vite打包出现 “default“ is not exported by “node_modules/...问题

项目场景:

uniapp+vue3+ts+vite

问题描述:场景很多,下面只是一种

javascript 复制代码
// codemirror 编辑器的相关资源
import Codemirror from 'codemirror';


error during build:
RollupError: "default" is not exported by "node_modules/vue/dist/vue.runtime.esm-bundler.js", imported by "node_modules/@kangc/v-md-editor/lib/codemirror-editor.js".
    at error (file:///D:...

原因分析:

报错意思是导入的js文件没有默认导出,这才是重点

解决方案:

有两种方法

1.修改node_modules下的文件源码,或者**你自己本地代码里的js文件源码。**在前面加上expoert default

javascript 复制代码
export default (function (global, factory) {
  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
    typeof define === 'function' && define.amd ? define(factory) :
      (global = global || self, global.CodeMirror = factory());
}(this, (function () {
  'use strict';

为这个js文件添加一个默认导出。不太推荐这个方法,虽然比较简单

2.安装@rollup/plugin-commonjs插件,vite-plugin-require-transform插件@rollup/plugin-commonjs可以将commonjs模块转换层es6模块,但只会对require生效,所以需要将导入改为require格式

(1)安装插件

javascript 复制代码
npm i @rollup/plugin-commonjs
npm i vite-plugin-require-transform

(2)添加配置

vite.config.ts配置中添加插件,注意commonjs()必须在上面,否则可能不生效

javascript 复制代码
import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';
import commonjs from '@rollup/plugin-commonjs';//引入commojs
import requireTransform from 'vite-plugin-require-transform';//引入require
export default defineConfig({
  plugins: [
    commonjs() as any,
    //我的入口文件是ts类型,所以下面必须加上.ts$,否则在main.ts无法使用require
    requireTransform({
      fileRegex: /.js$|.vue$|.png$|.ts$|.jpg$/
    }) //配置require
    vue(),
  ],
 }

(3)将main.ts中的导入改为require

javascript 复制代码
// codemirror 编辑器的相关资源
const Codemirror = require('codemirror');
相关推荐
C_心欲无痕25 分钟前
网络相关 - 常用命令详解Telnet、Ping 及其他实用工具
前端·网络
JarvanMo34 分钟前
没有人比我更懂Flutter第三方依赖鸿蒙化了之Sqflite
前端
子洋1 小时前
AI Agent 设计模式 - PlanAndExecute 模式
前端·人工智能·后端
仰望.1 小时前
vue 甘特图 vxe-gantt 如何实现标记删除数据,显示标记删除后行效果,获取已标记的行数据
vue.js·甘特图·vxe-ui
web小白成长日记1 小时前
自定义 Hooks 的用法和意义详解(结合案例)
前端·css·面试·职场和发展·前端框架
小鸡脚来咯1 小时前
前端传输的数据格式的选择
java·开发语言·前端·后端
小二·1 小时前
【万字源码级剖析】深入理解 Vue 3 响应式系统:ref、reactive、computed 与 effect 的底层实现
前端·javascript·vue.js
Mintopia2 小时前
“开源”和“闭源“,AI 模型的发展方向
前端·人工智能·aigc
Mintopia2 小时前
哈珀·李的《**杀死一只知更鸟**》(*To Kill a Mockingbird*)是一部关于**人性、正义与道德成长**的小说
前端
什么都不会的Tristan2 小时前
Feed流(关注推送)
java·前端·数据库