में एकाधिक रेड्यूसर में क्रियाओं का पुन: उपयोग करना, इसलिए मैं एक बड़े प्रतिक्रिया/रेडक्स ऐप पर काम कर रहा हूं और यह बहुत खुश हूं कि यह रेडक्स में राज्य का प्रबंधन कितना आसान है। हम चीज़ों को अपेक्षाकृत डोमेन आधारित रखने के लिए रेड्यूसर/एक्शन/एक्शन क्रिएटर के लिए "बतख" शैली दृष्टिकोण का उपयोग कर रहे हैं। इसके अलावा, हम डोमेन से जुड़े ui राज्य को रखने की कोशिश करते हैं और अधिकांश रेड्यूसर की समान संरचना होती है।रेडक्स
export default function home(state = initialState, action = {}) {
switch (action.type) {
case OPEN:
return {
...state,
ui: {
...state.ui,
[action.key]: true
}
};
case CLOSE:
return {
...state,
ui: {
...state.ui,
[action.key]: false
}
};
case SELECT_TAB:
return {
...state,
ui: {
selectedTab: action.selected
}
};
default:
return state;
}
}
हम अंत में एक ही कार्रवाई ui के लिए अधिक से अधिक दोहराया, मुख्य रूप से टॉगल और स्थापित करने के लिए क्या प्रदर्शित किया जाता है होने: यह इस तरह दिखता है। प्रत्येक रेड्यूसर में ui के लिए OPEN
और CLOSE
टाइप स्टेटमेंट में जोड़ने के बिना डोमेन आधारित ui को रेड्यूसर में रखने का कोई तरीका है। शायद मैं जो सोच रहा हूं वह रेडक्स में एक विरोधी पैटर्न है लेकिन यह देखने के लिए उत्सुक है कि क्या कोई इस तरह के मुद्दे में भाग गया है?
अद्यतन:
मैं नीचे सूचीबद्ध समाधान चाहते हैं, लेकिन तुम कैसे कम करने सबसे छुटकारा पाना चाहती भीतर एक ui कम करने को रोकने के लिए विस्तार होगा।
combineReducers({
home: {createUiReducer('home', initialState), ...home}
})
इस तरह आप सभी कार्यों को दोहराए बिना डोमेन आधारित ui नेस्टेड कर सकते हैं। सुनिश्चित नहीं है कि आप इसके बारे में कैसे जाएंगे क्योंकि आप अनिवार्य रूप से गतिशील रूप से केस विवरण जोड़ना चाहते हैं।
उत्तर के लिए धन्यवाद, लेकिन मैं पहले से ही है, आप कर रहे हैं, जैसे सबसे डेवलपर्स रहे हैं, आलसी, तो एक सहायक समारोह जो आपके लिए reducers उत्पन्न होगा बनाने प्रत्येक क्रिया का नाम 'कॉन्स्ट ओपन =' अगर योजना/घर/ओपन '; ' मुझे लगता है कि मुझे काफी कुछ नहीं मिलता है, भले ही मेरे पास एक सहायक कार्य था जिसमें डिफ़ॉल्ट ui क्रियाओं का एक सेट था। मैं इसे मूल reducer के अंदर कहां रखूँगा? –
@ फिलिप चम्लेट्स संपादन की जांच करें .. इस तरह मैं इसका उपयोग करूंगा .. – webdeb
इतनी नज़दीकी है, लेकिन होम रेड्यूसर में अन्य कार्रवाइयों की समस्या को ठीक से हल नहीं करता है, जिसे मैं हासिल करने की कोशिश कर रहा हूं । –