
本文详解如何通过配置 jodit 的 `uploader` 选项,实现从本地选择图片后自动上传至指定后端接口(如 `/files`),并正确插入服务器返回的图片 url 到编辑器中,无需手动处理文件选择与 dom 插入。
Jodit 编辑器原生支持高度可定制的图片上传流程,关键在于正确配置 config.uploader 对象。你无需接管文件选择逻辑(如 ),也不需手动调用 axios 或操作 DOM 插入 标签——Jodit 会在用户点击「插入图片」或拖拽图片到编辑区时,自动触发上传流程,并根据响应结果智能插入图片。
以下是你需要集成到 config 中的核心 uploader 配置(已适配你的后端要求):
uploader: {
insertImageAsBase64URI: false, // 禁用 base64,强制走 URL 插入
imagesExtensions: ['jpg', 'jpeg', 'png', 'gif'], // 允许的图片格式
method: 'POST',
url: 'http://localhost:3000/files', // 你的后端上传地址
headers: {
// ⚠️ 注意:不要手动设置 'Content-Type'
// 浏览器会自动添加 boundary,设为 multipart/form-data 会导致 400 错误
},
prepareData: function (data) {
// this.file 是 Jodit 自动捕获的 File 对象
data.append('file', this.file);
return data;
},
isSuccess: function (resp) {
// 假设后端成功响应为纯字符串(如 "https://cdn.example.com/img.png")
// Jodit 默认期望 resp.error === undefined 或 falsy
return typeof resp === 'string' && resp.startsWith('http');
},
process: function (resp) {
// 将纯字符串响应包装为 Jodit 期望的格式
return {
files: [resp], // 必须是数组,且首个元素即图片 URL
path: '',
baseurl: '',
error: 0,
msg: 'Upload successful'
};
},
defaultHandlerSuccess: function (data, resp) {
const url = Array.isArray(data.files) && data.files[0] ? data.files[0] : '';
if (url) {
// 插入图片,宽度设为 250px(可按需调整)
this.selection.insertImage(url, null, 250);
}
},
defaultHandlerError: function (resp) {
const msg = typeof resp === 'string' ? resp : 'Upload failed';
this.events.fire('errorPopap', this.i18n(msg));
}
}✅ 关键注意事项:
- 不要手动设置 Content-Type 头:FormData 上传必须由浏览器自动设置 Content-Type: multipart/form-data; boundary=...,硬编码会导致请求失败;
- 后端响应必须为 JSON 或可解析结构:虽然你提到“只返回一个字符串”,但 Jodit 的 process 函数仍需接收该字符串作为 resp 参数。若后端实际返回纯文本(非 JSON),需确保 Axios 响应配置 responseType: 'text' —— 但更推荐后端统一返回标准 JSON,例如:{ "data": "https://..." };
- 若后端返回的是 JSON 对象(如 { "data": "https://..." }),则 process 应改为:
process: function (resp) { return { files: [resp.data], path: '', baseurl: '', error: resp.error ? 1 : 0, msg: resp.message || 'Success' }; } - isSuccess 函数用于判断响应是否成功,返回 true 时触发 defaultHandlerSuccess;否则走错误流程;
- insertImage 的第三个参数为默认宽度(单位 px),传 null 表示不设宽高,由 CSS 控制。
最后,将上述 uploader 配置合并进你的 config 对象,并确保 enableDragAndDropFileToEditor: true 和 buttons: ['image'](或未被 removeButtons 移除)已启用,即可开箱即用:用户点击工具栏「图片」按钮、粘贴图片或拖拽图片到编辑区,全部自动完成上传与插入。
这样既保持了 Jodit 的原生交互体验,又完全解耦了前端上传逻辑,真正实现「配置即集成」。










