প্রতিক্রিয়াশীল Redux
ফ্যাশনে চলার জন্য প্রতিক্রিয়াশীল এবং দুজনেরই অপরিবর্তনীয়তার সাথে খাঁটি ফাংশন প্রয়োজন।
আপনি যদি এই দুটি জিনিস অনুসরণ না করেন তবে আপনার অ্যাপ্লিকেশনগুলিতে বাগ রয়েছে যা React/Redux
আপনার state/prop
পরিবর্তনগুলির পরিবর্তে ট্র্যাক করতে সক্ষম না হয়ে এবং পুনরায় রেন্ডার করতে অক্ষম ।
প্রতিক্রিয়া হিসাবে, নিম্নলিখিত উদাহরণ বিবেচনা করুন:
let state = {
add: 0,
}
function render() {
//...
}
//pure function
function effects(state,action) {
//following immutability while updating state, not directly mutating the state.
if(action == 'addTen') {
return {...state, add: state.add + 10}
}
return state;
}
function shouldUpdate(s) {
if(s === state){
return false
}
return true
}
state = effects(state, 'addTen')if(shouldUpdate(state)) {
render();
}
রাজ্যটি রাষ্ট্রীয় অবজেক্টের অধীনে থাকে যা কেবল সম্পত্তি যুক্ত করে। এই অ্যাপ্লিকেশনটি অ্যাপটির সম্পত্তি সরবরাহ করে। যখন কিছু ঘটে তখন সর্বদা রাষ্ট্রকে রেন্ডার করা উচিত নয় তবে রাষ্ট্রের বস্তুতে কোনও পরিবর্তন এসেছে কিনা তা যাচাই করা উচিত।
এর মতো, আমাদের একটি প্রভাব ফাংশন রয়েছে, pure function
যা আমরা আমাদের রাজ্যকে প্রভাবিত করতে ব্যবহার করি। আপনি দেখতে পাচ্ছেন যে রাষ্ট্রটি পরিবর্তন করতে হবে যখন এটি একটি নতুন রাজ্যে ফিরে আসে এবং যখন কোনও পরিবর্তন প্রয়োজন হয় না তখন একই রাষ্ট্রটি প্রদান করে।
আমাদের একটি shouldUpdate
ফাংশন রয়েছে যা === অপারেটরটি ব্যবহার করে যাচাই করে তা পুরাতন রাষ্ট্র এবং নতুন রাজ্য একই কিনা।
প্রতিক্রিয়া শর্তাবলী ভুল করতে, আপনি আসলে নিম্নলিখিত করতে পারেন:
function effects(state,action) {
doRandom(); // effects should only be called for updating state.
// Doing any other stuff here would make effects impure.
if(action == 'addTen') {
return {...state, add: state.add + 10}
}
return state;
}
আপনি সরাসরি রাষ্ট্র সেট করে এবং effects
ফাংশনটি ব্যবহার না করেও ভুল করতে পারেন ।
function doMistake(newValue) {
this.state = newValue
}
উপরের কাজটি করা উচিত নয় এবং কেবলমাত্র effects
ফাংশনটি রাষ্ট্র আপডেট করতে ব্যবহার করা উচিত।
প্রতিক্রিয়া effects
হিসাবে , আমরা হিসাবে কল setState
।
রেডাক্সের জন্য:
- রেডাক্সের
combineReducers
ইউটিলিটি রেফারেন্স পরিবর্তনের জন্য পরীক্ষা করে।
- রিঅ্যাক্ট-রেডাক্সের
connect
পদ্ধতিটি এমন উপাদানগুলি উত্পন্ন করে যা মূল অবস্থা এবং mapState
ফাংশন থেকে রিটার্ন মান উভয়ের জন্য রেফারেন্স পরিবর্তনগুলি পরীক্ষা করে দেখে বোঝায় যে মোড়ানো উপাদানটি আসলে পুনরায় রেন্ডার করা দরকার।
- সময়-ভ্রমণের ডিবাগিংয়ের দরকার হয় যে হ্রাসকারী
pure functions
কোনও পার্শ্ব প্রতিক্রিয়া না করে যাতে আপনি বিভিন্ন রাজ্যের মধ্যে সঠিকভাবে লাফিয়ে উঠতে পারেন।
আপনি হ্রাসকারী হিসাবে অপরিষ্কার ফাংশন ব্যবহার করে উপরের তিনটি সহজেই লঙ্ঘন করতে পারেন।
নীচে সরাসরি রিডেক্স ডক্স থেকে নেওয়া হয়:
একে রিডুসার বলা হয় কারণ এটি আপনার ধরণের ফাংশনটি কেটে দেবে Array.prototype.reduce(reducer, ?initialValue)
।
এটি খুব গুরুত্বপূর্ণ যে হ্রাসকারী খাঁটি থাকে। রিডিউসারের অভ্যন্তরে আপনার যে জিনিসগুলি করা উচিত নয়:
Mutate its arguments;
Perform side effects like API calls and routing transitions;
Call non-pure functions, e.g. Date.now() or Math.random().
একই আর্গুমেন্ট দেওয়া, এটি পরবর্তী অবস্থা গণনা করা উচিত এবং এটি ফিরে আসতে হবে। কোন চমক নাই. কোন পার্শ্ব প্রতিক্রিয়া। কোনও এপিআই কল নেই। কোনও মিউটেশন নেই। শুধু একটি হিসাব।
window.getElementById
ইত্যাদির মতো কিছু তাই একই পরামিতিগুলির সাথে একই ফাংশনটি চালানো পার্শ্ব প্রতিক্রিয়াগুলির উপর নির্ভর করে বিভিন্ন ফলাফল পেতে পারে। হ'ল রিডাক্স ব্যর্থ হবে।