使用了 URL.createObjectURL(resData.data) 但是图片还是没有反显成功
时间: 2024-09-21 13:03:01 浏览: 64
如果使用了`URL.createObjectURL(resData.data)`并将结果设置给了Quill Editor,但图片仍然无法正常反显,可能有以下几个原因:
1. **检查数据格式**:确保`resData.data`是一个Blob对象,而非其他格式的数据,因为`createObjectURL`只适用于Blob。
2. **插入方式**:确认是否正确地将URL插入到了编辑器,可能是位置不对,或者插入方法有问题。应该像这样操作:
```javascript
const quillImage = await Quill.getInstance().insertEmbed(index, 'image', url, true);
```
3. **编辑器配置**:确保编辑器的配置支持img标签或者已正确设置了富文本插件来显示图片。某些插件可能需要特定的方式插入图片。
4. **浏览器兼容性**:有些旧版浏览器可能不支持`createObjectURL`,考虑做一下polyfill或者提供备选方案。
5. **错误处理**:检查是否有异常抛出,可能是网络请求失败,图片加载失败等问题。
如果尝试以上步骤仍无果,建议打印日志,查看`url`变量的实际内容,或者直接尝试在页面上展示看是否能正常显示。
相关问题
window.URL.createObjectURL 何时使用URL.revokeObjectURL(url)
`window.URL.createObjectURL()` 是浏览器提供的一个方法,用于创建一个表示特定媒体文件、Blob对象或Data URL 的唯一URL。当你需要将二进制数据、图片或其他类型的资源作为URL传递给DOM元素(如`<img>`标签)时,可以使用这个方法生成临时URL。
例如,在网页上预加载图片时,会先使用`createObjectURL`生成一个URL,然后设置到`src`属性:
```javascript
let img = new Image();
const blob = ...; // 图片 Blob 对象
img.src = URL.createObjectURL(blob);
```
当你不再需要这个URL时,应当使用 `URL.revokeObjectURL(url)` 来释放资源并避免内存泄漏。这通常发生在用户关闭窗口、页面卸载或主动删除对应的DOM元素时:
```javascript
img.onload = function() {
URL.revokeObjectURL(img.src); // 当图片加载完成后,撤销URL
};
```
URL.createObjectURL显示图片
URL.createObjectURL()方法可以用来创建一个指向传入参数对象的URL。在上述引用[3]的代码中,通过使用URL.createObjectURL()方法,可以将获取到的图片Blob数据转换为一个URL,然后将这个URL赋值给img的src属性,从而显示图片。在代码中,还使用了URL.revokeObjectURL()方法来释放这个URL,告诉浏览器不再需要指向对应的文件了。这样就可以通过URL.createObjectURL()方法来显示图片。
阅读全文