反应Filepond加载初始图像不起作用

编程入门 行业动态 更新时间:2024-10-09 11:22:47

反应Filepond加载初始图像<a href=https://www.elefans.com/category/jswz/34/1771377.html style=不起作用"/>

反应Filepond加载初始图像不起作用

我在使用Filepond for React时遇到了一些麻烦。当前,我想在加载页面时预加载用户的个人资料图片。我尝试了两种不同的方法,但都没有成功:

首先,我尝试像这样使用Filepond的服务器加载选项:

<FilePond
   ref={pond}
   ... other props here
   files={[
   {
     source: this.props.user.id,
     options: {
     type: 'local'
   }
   }
   ]}
   server={{
   load: (userId, load) => {
   fetch(fetchDomain + "/profiles/" + userId)
     .then(res => res.blob())
     .then(blob => {
        console.log('blob is: ', blob)
        return load
     })
   }
   }}
/>

我从在相同域上运行的Express后端获取,并返回s3图片网址。这将导致无限的加载情况,并且永远不会加载图片。我一直在对此尝试进行小的更改以修复它,但始终无法使其工作。在某些时候,当我弄乱代码时,它将完成加载,但是图像将是灰色/不可用,没有错误消息。

[我采取的另一种方法只是将“文件”设置为图像URL,但这也不起作用。同样的结果,一个灰色的图像,我可以通过单击“删除项目”按钮将其清除。但是,我确实注意到,如果该URL是base64 URL,它将实际上正确加载图像。

我已经调试了几个小时。我在这里缺少什么吗?

我不确定是否相关,但是文件顶部的设置如下:

import 'filepond/dist/filepond.min.css';
import CropperEditor from './Cropper';
import FilePondPluginFileValidateType from "filepond-plugin-file-validate-type";
import FilePondPluginImageExifOrientation from "filepond-plugin-image-exif-orientation";
import FilePondPluginImagePreview from "filepond-plugin-image-preview";
import FilePondPluginImageCrop from "filepond-plugin-image-crop";
import FilePondPluginImageResize from "filepond-plugin-image-resize";
import FilePondPluginImageTransform from "filepond-plugin-image-transform";
import FilePondPluginImageEdit from "filepond-plugin-image-edit";
import 'filepond-plugin-image-preview/dist/filepond-plugin-image-preview.css';
const fetchDomain = process.env.NODE_ENV === 'production' ? process.env.REACT_APP_FETCH_DOMAIN_PROD : process.env.REACT_APP_FETCH_DOMAIN_DEV;

// Register the plugins for filepond
registerPlugin(
  FilePondPluginFileValidateType,
  FilePondPluginImageExifOrientation,
  FilePondPluginImagePreview,
  FilePondPluginImageCrop,
  FilePondPluginImageResize,
  FilePondPluginImageTransform,
  FilePondPluginImageEdit,
);

const pond = React.createRef();

[这是我摆脱了FilePondPluginImagePreview以外的所有插件并使用第一种方法后,加载时组件外观的图片:

It says undefined...

在进一步阅读了文档之后,我现在对于应该加载还是获取感到困惑。

回答如下:

我当时错误地理解了服务器的加载和获取功能。我必须先获取图像URL,然后在服务器中使用访存或加载,才能从该URL获取文件,然后将其转换为Blob格式。这也可以与服务器端点配合使用,就像我最初尝试做的那样,但是您必须确保服务器返回文件而不是URL。我猜它可能会返回一个URL,但是您必须对该URL进行另一个提取,然后将其转换为Blob。

这个问题的答案实际上是我所做的。

File Preview in React FilePond not showing up when setting initial file

更多推荐

反应Filepond加载初始图像不起作用

本文发布于:2024-05-07 10:03:16,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1755735.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:不起作用   图像   加载   Filepond

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!