首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >我无法在获取api Reactjs中设置状态值

我无法在获取api Reactjs中设置状态值
EN

Stack Overflow用户
提问于 2022-08-22 18:38:02
回答 1查看 28关注 0票数 0

我试图通过设置lazyload来创建无限滚动,但不能在postData函数中每次设置状态。

我可以看到arr数组正常工作,但它没有在setCards(arr)中设置。我看不到Devtolls组件工具中的更新

如果你知道的话.

代码语言:javascript
复制
const postData = async (searchInputValue,payload) => {
    const response =  await fetch("https://smarty.kerzz.com:4004/api/mock/getFeed", {
        body: JSON.stringify(payload),
        headers: {
            Accept: "application/json",
            Apikey: "bW9jay04ODc3NTU2NjExMjEyNGZmZmZmZmJ2",
            "Content-Type": "application/json"
        },
        method: "POST"
        })
    const data = await response.json()
    let arr =[...cards]
    console.log(cards)
    data.response.forEach((item, idx)=>{
       arr.push(item)

    })
    console.log(arr)  //[]
    setCards(arr)
    let a = counter + 1
    let new_payload = payload;
    new_payload.skip += 10*a
    setPayload(new_payload)
    setCounter(a)
 }

useEffect(()=>{
 // İlk yükleme sırasında lokasyon verisini alıp fonksiyonu çağırıyoruz. Aldığımız lokasyon 
verisine göre işlemlere devam edeceğiz.
findLocation();
window.addEventListener('scroll' , ()=>{
  let screen_height = window.innerHeight;
  let scrollTop = document.documentElement.scrollTop;
  var body = document.body,
  html = document.documentElement;

  var body_heigth = Math.max( body.scrollHeight, body.offsetHeight, 
                    html.clientHeight, html.scrollHeight, html.offsetHeight );
  
  if(scrollTop + 1 > body_heigth - screen_height && isloading === false && checked === false){ 
    setIsloading(true)
    postData(searchInputValue , payload)
  }
})
},[])
EN

回答 1

Stack Overflow用户

发布于 2022-08-22 18:45:16

如果使用以前的状态计算新状态,则可以将一个函数传递给setState。该函数将接收前一个值,并返回一个更新的值。

https://reactjs.org/docs/hooks-reference.html#functional-updates

示例:

代码语言:javascript
复制
setCounter((counter)=>(counter+1))
setCards((cards)=>(cards.concat(data.response)))

对于setPayload也要这样做。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73449653

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档