2016-03-06 51 views
3

我正在處理React/Redux應用程序,並且大部分情況下,一切都一直順利進行。使用Object.assign正確地返回嵌套狀態

從本質上講,它是具有內置的。

我無法在我的減速器中正確返回全部現有的狀態下,當用戶添加一個類別裏面待完成項目分類待辦事項應用程序。

了Redux狀態之前,我派遣行動方法add_item看起來是這樣的:

{ 
items: { 
    "HOME": [["Do laundry", "High Priority"],["Feed kids", "Low priority"] ], 
    "WORK": [["Get promotion", "High priority"],["Finish project", "Medium priority"] ], 
    "BOTH": [["Eat better", "Medium priority"],["Go for a run", "High priority"] ], 

}, 
settings: { 
    Test: "test" 
} 
} 

用戶導航到一個類別(預製作,還沒有實現創建它們還),可以創建一個新的todo-具有名稱和優先級的項目。這將調度一個返回數組的類型,如[category,name,priority]。

目前在我的減速器中,我已經在它成功添加項目的地方,但它正在清空/覆蓋所有現有的類別。

我的減速器是這樣的:

case types.ADD_ITEM: 
let cat = action.payload[0]; 
let name = action.payload[1]; 
let priority = action.payload[2]; 
return Object.assign({}, state, { items: { [cat]: [...state.items[cat], [name, priority]]}}); 

我試圖創建一個新的對象首先與所有的合併項目,像這樣:

let combinedItems = Object.assign({}, state.items, { [cat]: [...state.items[cat], action.payload] }); 

如果我CONSOLE.LOG上述combinedItems,我得到我想要項目的確切對象。但是,我正在努力讓減速器返回的最終對象反映這一點。

當我嘗試像下面這樣的東西時,我得到一個包含combinedItems的對象作爲項目中的單獨鍵。

 return Object.assign({}, state, { items: { combinedItems, [cat]: [...state.items[cat], [name, priority]]}}); 

任何人都可以幫助我得到我的最終REDX狀態來包含所有現有的類別/項目+用戶添加一個?我真的很感謝幫助。

+0

你說你的初始狀態有鑰匙'todos'和'settings'但後來使用了'items'和'settings'走了......實際發生了什麼? – azium

+0

'Object.assign'不會做很深的擴展。 – Bergi

+0

@azium:道歉。在我發佈這個消息之前,我已經改變了一些名字,這是前一個版本的遺留物。現在應該是正確的。 – intoxxx

回答

3

我認爲你應該在你有數組的地方使用對象。在你的行動有效載荷,而不是,:

[category, name, priority] 

您可以:

{category, name, priority} 
action.payload.category 

我會讓你的待辦事項相同的變化。相反的:

[["Eat better", "Medium priority"], ... ] 

您可以:

[{ name: "Eat better", priority: "Medium" }, ... ] 

現在它是否是更好地使items與種類鍵的對象,或者是知道它的類別項目的數組方面......我好認爲後者更好,這樣如果你得到一個單一的項目,你不需要去它的父母找出它屬於哪個類別。這也會讓你的問題更易於管理。

items: [ 
    { 
    name: "Eat better", 
    priority: "Medium", 
    category: "Both" 
    }, ... 
] 

把所有這一切共同解決您的問題:

case types.ADD_ITEM: 
    let newItem = { 
    name: action.payload.name, 
    priority: action.payload.priority, 
    category: action.payload.category 
    } 
    return Object.assign({}, state, { items: [ ...state.items, newItem ] }) 

無論你受益與類別,鍵之前必須是微不足道重現這種結構。

獲取在HOME類別中的所有項目:

this.props.items.filter(item => item.category === 'HOME') 
+1

如果你真的想保留你的物品結構,讓我知道,我會更新我的答案來使用它,但我強烈推薦我目前的方法。 – azium

+0

這看起來非常棒。我現在要將它實現到我的項目中,並且讓我知道它是如何發生的。必須重構其他幾個位置來解釋新的對象結構。謝謝!! – intoxxx

+1

我將它全部實施並且工作得很好!我非常感謝你幫助我解決這個問題。當我開始創建類別和內容時,這將是一個非常大的幫助。感謝好的想法。 – intoxxx