1

Fetching a list of objects. I loop through the list to retrieve an image in each object and store it in the localStorage.

// storing images in localStorage
  storeMovieImagesLocalStorage = (movieList) => {
    movieList.map(movie => {
        localStorage.setItem(movie.id, this.getBase64Image(movie.images[0].url))
    })
  };


// converting url to base64
  getBase64Image = (img) => {
    const canvas = document.createElement("canvas");
    const ctx = canvas.getContext("2d");

    // create new Image to assign image url
    const image = new Image();
    image.src = img;
    image.onload = function() {
      const canvas = document.createElement("canvas");
      canvas.width = image.width;
      canvas.height = image.height;
      ctx.drawImage(image, 0, 0);
    };

    const dataURL = canvas.toDataURL("image/png");

    return dataURL;
  };

Then I apply the base64 code to my image.

      this.setState({
        movieUrl: localStorage.getItem(movie.id)
      })

        <MovieImg src={this.state.movieUrl} className="cursor-pointer" onClick={this.handleOpenVideo} />

My localStorage is storing the right information properly:

{ 2-guns: "" }

Here what I find the devTools/Elements:

<img class="Img-sc-10y4zbe-0 cursor-pointer sc-ifAKCX cmjWax" src="">

All seems fine to me and I do not have any error in my console. However, my image is not displayed. and when I hover above the img[src], it shows me an invisible image, or and image that does not have content.

What have I done wrong?

3
  • 2
    The image hasn't loaded yet at the time you call toDataURL, so the canvas is still blank. Commented May 26, 2019 at 8:55
  • So I realized that I was downloading jpeg images and I was adding png to my img[src]. So I got that fixed and now it is displaying something but I have black boxes rather than just nothing. Commented May 26, 2019 at 8:55
  • 1
    @Herohtar, I am working on something, I think you are right. Looking at using onLoad function. Commented May 26, 2019 at 9:09

1 Answer 1

0

i attempted to convert your base64 string back to an image again, the part between "iVBOR" and "SuQmCC". but that doesnt appear to be a valid image returned from that.

i tried with another base64 string representing an image using your exact html tag with attributes and that works just fine:

<img src="
AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
    9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" class="Img-sc-10y4zbe-0 cursor-pointer sc-ifAKCX cmjWax">

it seems the problem is that you have an incorrect base64 string of the image which is why nothing shows up. worth noting is that i have no idea what your specific classes do so i cant speak for their behavior.

Sign up to request clarification or add additional context in comments.

1 Comment

The classes are fine, they have nothing that will affect it. I think @Herohtar has sent me on the right track. All 30 pictures have the same base64 which is odd, which makes me think the image is not laoded yet.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.