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

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

React Native 所選項目未向 UI 反映狀態

React Native 所選項目未向 UI 反映狀態

萬千封印 2023-07-20 10:08:43
我正在嘗試開發一個組件,該組件應顯示我的數據庫中的所有成分,但狀態尚未按預期更新。變量:  const image = require('../../assets/backgroundMeal.png');  const [name, setName] = useState('')  const [ingredients, setIngredients] = useState([])  const [recipes, setRecipes] = useState([])  const [ingredientList, setIngredientList] = useState([{id:null, name:null, isSelected:false}])API 調用:useEffect(() => {    let recipeRequest = 'http://192.168.0.3:3333/report'    let ingredientsRequest = 'http://192.168.0.3:3333/ingredients'    recipeRequest = axios.get(recipeRequest)    ingredientsRequest = axios.get(ingredientsRequest)        axios.all([recipeRequest, ingredientsRequest])          .then(axios.spread((...responses) => {            setRecipes(responses[0].data)            setIngredientList(responses[1].data)          }))          .catch(function (error) {            console.log('API CALL - recipe/ingredient - error: ', error);          })      },[ingredientList])變量“ingredientsRequest”包含所有成分。這是將“isSelected”與“ingredientList”連接起來的變量  const [allItems, setAllItems] = useState([ingredientList]);  const selectedIngredient = (item) => {    let temp = allItems.filter(parentItem => parentItem.id !== item.id)    item.isSelected = !item.isSelected;    temp = temp.concat(item);    temp.sort((a, b) => parseInt(a.id) - parseInt(b.id))        setAllItems(temp)    console.log('## allItems', allItems)這是第一個問題,我聲明形狀“id”和“name”iguals為空的狀態,并且useEffect axios調用應該更新“setIngredientList”并且應該更新“ingredientList”,但是console.log我在“返回”之前調用表明對象仍為空值,ID 和 NAME 變量為空值。它應該在我在 useEffect 處的 axios 調用中更新,為什么它沒有?“allItems”變量處的 console.log 結果。數組 [ 對象 { "id": null, "isSelected": false, "name": null, },一旦我單擊 Flatlist 組件,它就會正確更新“isSelected”狀態,但不會顯示所有“ingredientList”狀態,即使考慮到“allItems”變量使用 useState([ingredientList]),所以我認為應該有成分列表形狀,對嗎?
查看完整描述

1 回答

?
長風秋雁

TA貢獻1757條經驗 獲得超7個贊

試試這個,它會反映在用戶界面上的選擇上


const selectedIngredient = (item, index) => {

    const tempAllItems = [...allItems];

    tempAllItems[index].isSelected = !item.isSelected;

    

    setAllItems(tempAllItems);

}


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

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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