Base64字符串图像无法正确显示

时间:2018-10-15 21:52:18

标签: javascript reactjs

我正在尝试显示来自base64字符串的图像,但它一直像这样显示:

img

我尝试打印img并得到如下信息:

我尝试通过执行<img src={this.state.img} />仅显示它是错误的吗?感谢您的帮助!

编辑:我还更新了此帖子,以包含如何生成base64代码。本质上,我上传图像并使用https://www.npmjs.com/package/react-image-crop裁剪该图像。然后,我要显示裁剪的图像,这就是发生问题的地方

<div>
     <input type="file" onChange={this.onSelectFile} />
</div>

onSelectFile = e => {
    if (e.target.files && e.target.files.length > 0) {
      const reader = new FileReader();
      reader.addEventListener(
        "load",
        () =>
          this.setState({
            src: reader.result,
            openCropper: true
          }),
        false
      );
      reader.readAsDataURL(e.target.files[0]);
    }
  };


function getCroppedImg(image, pixelCrop, fileName) {

  const canvas = document.createElement('canvas');
  canvas.width = pixelCrop.width;
  canvas.height = pixelCrop.height;
  const ctx = canvas.getContext('2d');

  ctx.drawImage(
    image,
    pixelCrop.x,
    pixelCrop.y,
    pixelCrop.width,
    pixelCrop.height,
    0,
    0,
    pixelCrop.width,
    pixelCrop.height
  );

  // As Base64 string
  const base64Image = canvas.toDataURL('image/jpeg');
  return base64Image;

2 个答案:

答案 0 :(得分:1)

我相信您在base64 URL的末尾缺少等号。



答案 1 :(得分:1)

问题可能是由于调用onSelectFile的上下文所致。当前,您将onSelectFile定义为箭头函数。反过来,这意味着this.setState将在您的FileReader加载图像数据(然后尝试更新组件的状态)时未定义。

请考虑以下代码,概述可能的解决方案:

class App extends React.Component {
  constructor(props) {
    super(props)
    this.state = {
        src:''
    }
  }

  // Define as class method rather than arrow function
  onSelectFile(e) {

    if (e.target.files && e.target.files.length > 0) {
      const reader = new FileReader();
      reader.addEventListener(
        "load",
        () =>
          this.setState({
            src: reader.result,
            openCropper: true
          }),
        false
      );
      reader.readAsDataURL(e.target.files[0]);
    }
  }

  render() {
    return (
      <div>
     {/* invoke onSelectFile in this way to ensure calling context is 
         current component */}
     <input type="file" onChange={(e) => this.onSelectFile(e)} />
     <img src={this.state.src} />
      </div>
    )
  }
}

ReactDOM.render(<App />, document.querySelector("#app"))

对于有效的演示,please see this jsFiddle-希望这会有所帮助!