Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
96 views
in Technique[技术] by (71.8m points)

javascript - ReactJS simple image upload buffer displays null

Inside a component, I have an input field for an image like so:

function AFunction () {

    const [imageTitle, setImageTitle] = useState("")
    const [buffer, setBuffer] = useState(null)

    // for file (does not work)
    <input type='file' accept=".png, .jpg, .jpeg" onChange={(event) => {
                    event.preventDefault()
                    const file = event.target.files[0]
                    const reader = new window.FileReader()
                    reader.readAsArrayBuffer(file)
                
                    reader.onloadend = () => {
                        setBuffer(Buffer(reader.result))
                        console.log('buffer', buffer)
                    }
    }} />

    // for title (works)
    <input id="imageTitle" type="text" value={imageTitle} onChange={e => setImageTitle(e.target.value)} />

}

This code gets the title correctly, but displays the buffer as null

Full behaviour:

  1. Upload image from file...
  2. Image gets uploaded
  3. console.log displays null
  4. further debugging proves title is known after a change in input field

I tried altering the useState parameter with "", also does not work.

question from:https://stackoverflow.com/questions/65887894/reactjs-simple-image-upload-buffer-displays-null

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

setState in React is asynchronous, therefore you console log the previous state.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...