亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

React useState 鉤子影響狀態中使用的默認變量,無論擴展運算符

React useState 鉤子影響狀態中使用的默認變量,無論擴展運算符

翻閱古今 2023-11-02 21:23:10
我是經驗豐富的 js/React 開發人員,但遇到了我無法解決的情況,而且我不知道如何修復它。我有一個具有許多不同狀態的上下文提供程序,但一種狀態如下所示:const defaultParams = {  ordering: 'price_asc',  page: 1,  perPage: 15,  attrs: {},}const InnerPageContext = createContext()export const InnerPageContextProvider = ({ children }) => {  const [params, setParams] = useState({ ...defaultParams })  const clearParams = () => {    setParams({...defaultParams})  }  console.log(defaultParams)  return (    <InnerPageContext.Provider      value={{        params: params,        setParam: setParam,        clearParams:clearParams      }}    >      {children}    </InnerPageContext.Provider>  )}我在頁面上有一個按鈕,它調用clearParams函數,并且應該將參數重置為默認值。但它不起作用即使當我console.log(defaultParams)在每個提供者重新渲染時,defaultParams當狀態改變時變量似乎也在改變我認為這不正常,因為我已經使用過{...defaultParams},它應該創建新變量,然后將其傳遞給useState鉤子。我努力了:const [params, setParams] = useState(Object.assign({}, defaultParams))const clearParams = () => {  setParams(Object.assign({}, defaultParams))}const [params, setParams] = useState(defaultParams)const clearParams = () => {  setParams(defaultParams)}const [params, setParams] = useState(defaultParams)const clearParams = () => {  setParams({    ordering: 'price_asc',    page: 1,    perPage: 15,    attrs: {},  })}除了第三種方法之外,上述方法都不起作用,我將相同的對象硬編碼為defaultParams. 這個想法是將 dafult 參數保存在某處,當用戶清除參數時恢復它。你們有什么想法可以做到這一點嗎?編輯: 這就是我更新參數的方式:const setParam = (key, value, type = null) => {    setParams(old => {      if (type) {        old[type][key] = value      } else old[key] = value      console.log('Params', old)      return { ...old }    })  }
查看完整描述

1 回答

?
慕碼人2483693

TA貢獻1860條經驗 獲得超9個贊

請說明您如何更新“params”。


如果代碼“params.attrs.test = true”中有類似的內容,那么defaultParams將被更改


如果old[type]不是簡單類型,它會在 defaultParams 中存儲對同一對象的引用。defaultParams.attrs === params.attrs。因為在初始化期間您解構了一個對象,但沒有解構其嵌套對象。


問題就在這里:old[type][key] = value


解決方案:


const setParam = (key, value, type = null) => {

    setParams(old => {

      if (type) {

        old[type] = {

          ...old[type],

          key: value,

        }

      } else old[key] = value

      return { ...old }

    })

  }


查看完整回答
反對 回復 2023-11-02
  • 1 回答
  • 0 關注
  • 116 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號