Vue3 Vite vue-quill图片大小插件踩坑

打包报错提示default 未被导出

报错信息如下

代码如下

javascript 复制代码
import { QuillEditor, Quill } from '@vueup/vue-quill'
import '@vueup/vue-quill/dist/vue-quill.snow.css'
// 引入图片缩放插件
import ImageResize from 'quill-image-resize-module'
Quill.register('modules/imageResize', ImageResize)

按照这种方式配置,在本地启动项目是不会报错的,只有打包发布的时候才能发现问题。

解决办法

上面的引入代码在网上随处可见,但是它并不适用于Vue3 + Vite4环境,我们需要对代码做出一些修改。

javascript 复制代码
import { QuillEditor } from '@vueup/vue-quill'
import '@vueup/vue-quill/dist/vue-quill.snow.css'

// 引入图片缩放插件
import 'quill-image-resize-module/image-resize.min.js'

const options = ref({
  theme: "snow",
  bounds: document.body,
  debug: "warn",
  modules: {
    // 工具栏配置
    toolbar: [
      ["bold", "italic", "underline", "strike"],       // 加粗 斜体 下划线 删除线
      ["blockquote", "code-block"],                    // 引用  代码块
      [{ list: "ordered" }, { list: "bullet" }],       // 有序、无序列表
      [{ indent: "-1" }, { indent: "+1" }],            // 缩进
      [{ size: ["small", false, "large", "huge"] }],   // 字体大小
      [{ header: [1, 2, 3, 4, 5, 6, false] }],         // 标题
      [{ color: [] }, { background: [] }],             // 字体颜色、字体背景颜色
      [{ align: [] }],                                 // 对齐方式
      ["clean"],                                       // 清除文本格式
      ["link", "image", "video"]                       // 链接、图片、视频
    ],
    // 图片缩放配置 具体需要哪些功能可以自行调整
    imageResize: {
      modules: ["Resize", "DisplaySize", "Toolbar"]
    }
  },
  placeholder: '请输入内容',
  readOnly: props.readOnly,
  theme: 'snow'
})

这里不再将ImageResize插件当作模块引入,而是直接引入对应的js文件。 运行命令 安装 @rollup/plugin-inject

shell 复制代码
pnpm add @rollup/plugin-inject -D

@rollup/plugin-inject相当于webpack.ProvidePlugin,它可以在全局中注入需要的依赖。安装完成后修改vite.config

javascript 复制代码
// 导入inject插件
import inject from '@rollup/plugin-inject'

// 在plugins属性下加入以下配置,它可以在全局注入quill
inject({
  'window.Quill': ['@vueup/vue-quill', 'Quill'],
  Quill: ['@vueup/vue-quill', 'Quill']
})

至此,插件可以正常引入,打包也不再报错

cannot read property 'imports' of undefined" 错误也可以使用上述方法解决
相关链接 github.com/kensnyder/q...

相关推荐
橘子味的冰淇淋~5 分钟前
优化前端性能之从“全局引入”改为“按需引入”
前端·javascript·vue.js
Anesthesia丶11 分钟前
Vite + Svelte + shadcn-svelte 最小化 Demo+Vue3语法对比总结
vue·vite·svelte·shadcn-svelte
Vennn26 分钟前
Android自动化:使用 Web 方式实现某音未读消息检查与采集
前端·javascript·vue.js
皮皮大人1 小时前
Vue 3 响应式内核完全解密:reactive & effect 与 Vue 2 Watcher 史诗对决
前端·vue.js
暗中讨饭xdm2 小时前
立体echarts柱状图咋做
前端·vue.js·echarts
w_t_y_y2 小时前
vue父子组件通信(一)父子调用和通信(2)VUE3
前端·javascript·vue.js
Cheney95012 小时前
Vue 项目字体文件打包后 fonts 文件夹“消失”?原因分析与解决方案
前端·javascript·vue.js
daols882 小时前
vxe-table 实现数据分组统计与表尾合计
前端·javascript·vue.js·vxe-table
向日的葵0062 小时前
Vue 函数定义、事件绑定与列表渲染精讲
前端·javascript·vue.js
喵个咪13 小时前
GoWind Toolkit 前端代码生成|Vue3(ElementPlus/Vben)、React(AntDesign)全自动一键生成教程
前端·vue.js·react.js