Estoy tratando de mostrar una imagen de una cadena base64 pero sigue apareciendo así:

img

Intenté imprimir la imagen y obtengo algo como esto: 

¿Me equivoco al intentar mostrarlo simplemente haciendo <img src={this.state.img} />? ¡Gracias por la ayuda!

EDITAR: También actualicé esta publicación para contener cómo estoy generando mi código base64. Básicamente, subo una imagen y la recorto usando https://www.npmjs.com / paquete / react-image-crop. Luego, quiero mostrar la imagen recortada y ahí es donde ocurre el problema.

<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
Tim 16 oct. 2018 a las 00:52

2 respuestas

La mejor respuesta

Los problemas pueden deberse al contexto desde el que se llama a su onSelectFile. Actualmente, estás definiendo onSelectFile como una función de flecha. Esto a su vez significa que this.setState no estará definido cuando su FileReader cargue los datos de la imagen (y luego intente actualizar el estado del componente).

Considere el siguiente código que describe una posible solución para su problema:

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"))

Para ver una demostración funcional, consulte este jsFiddle. ¡Espero que esto ayude!

1
Dacre Denny 15 oct. 2018 a las 22:17

Creo que le falta un signo igual al final de su URL base64.



1
Sensational Code 15 oct. 2018 a las 22:02