Skip to main content

Why Redux?

Redux giúp mình State management  - Quản lý State dễ thở hơn.

Nếu bạn đã truyền (passing) props giữa các component thì chắc bạn sẽ gặp 1 lúc mà việc pass đi như vậy phức tạp và rườm rà nếu tụi nó nest nhau quá nhiều tầng, hoặc nhiều component cùng dùng chung một cái state ở đẩu đâu đó, việc passing props vậy đúng là cực hình, phải truyền từng tầng từng tầng một  => code nhiều => thì chắc chắn sẽ nhiều bug hơn (không code thì không bug =)) ). Mà bug này là khóc luôn. Kiểu phải truyền xuống từng tầng một này hay gọi là Props drilling (also called "threading").

Redux với ý tưởng là sẽ tạo 1 cái "store" to bự chảng, chứa tất cả state mà app bạn cần dùng (share giữa nhiều component). Bạn cứ hiểu như nó là một cái component nằm ở đỉnh tree node của app. mấy cái node dưới sẽ là con nên sẽ access đến store được, chỉ cần connect vào là xong.

Cái nào cần dùng thì sẽ "connect" vào cái "store" và dùng state đó thông qua props như thông thường bạn pass props từ component cha sang component con. Khác với kiểu pass props thông thường thì bạn phải pass từng tầng một cho tới khi tới chỗ cần dùng. Thì redux cho phép bạn truyền trực tiếp chỗ cần xài thôi, không phải qua các component trung gian.

Và vì state được lưu ở một Store chung như vậy, và bạn biết rằng bên ngoài không thể tác động trực tiếp đến state được, nên cần phải raise event lên store để update. Nên Redux cung cấp "Action" - hiểu là các hành động, và "Reducer" sẽ phản ứng tương ứng với mỗi action và update state tương ứng.

Cần nhớ khi học redux: "Flux pattern" - One way road
Action => Dispatcher => Store => View
Image result for Flux pattern
(Nguồn: facebook.github.io)

trong Redux bạn sẽ thấy diagram kiểu như vầy:
Action => Reducer => Store => Make changes

Image result for redux diagram
(Nguồn: medium)

Action sẽ trigger Reducer thực hiện update state trong Store, và khi state updated thì Component sẽ thay đổi tương ứng (Make changes)

Trên đây là cách hiểu mình tóm gọn lại khi tìm hiểu về Redux, mong sẽ giúp bạn phần nào hiểu được cơ bản về Redux để dễ học. Đấy, cái idea chung chung là vậy.
Bây giờ bạn đọc docs của Redux hay xem tutorial, courses online sẽ dễ hiểu hơn rồi nha. YOLO

Mình cũng mới học thôi, nên nếu cách trình bày hay có gì sai sót mong được góp ý.

Comments

Popular posts from this blog

Arrow function lexical scoping

You can not bind arrow function They automatically get what called lexical scoping - which mean, they bind " this " context to the place where they were defined in the first place It's easier to write class method by using arrow function, so you can stop worry about bind " this "

Props vs State, Why?

Vì sao lại cần Props và State Khi người ta tạo ra các component, họ mới đặt câu hỏi làm sao để các component giao tiếp với nhau (từ parent tới child). Nên người ta mới nghĩ ra props (properties) để truyền data. Props là read-only , không thể thay đổi hay tác động (immutable) Nhưng khi một component cần react , render tùy theo tác động trực tiếp vào nó, nó cần data riêng để thể hiện sự thay đổi đó, nên người ta nghĩ ra sẽ cho component state (trạng thái) để thể hiện điều đó. State chỉ có thể update bởi chính component đó, bên ngoài không thể tác động

Recursion - Đệ quy là gì

"Recursion is when a function calls itself until it doesn't" Là một hàm gọi chính nó cho tới khi dừng. Vậy khi nào nó dừng? Khi nó thỏa điều kiện và không gọi chính nó nữa! (Duh? I'm I a joke to you) Vâng đúng là như vậy. Trong Recursion nó hai phần chính: - Base case: Trường hợp cơ bản - Tại case này, hàm sẽ không gọi lại chính nó nữa => Recursion sẽ dừng lại. - Recursive case: Trường hợp recursive - Như tên gọi, case này thì hàm sẽ tiếp tục gọi (recursive) chính nó tiếp. Ví dụ: Bằng bài toàn tìm giai thừa (factorial) function factorial(num) { if (num === 1 ) return 1 // Base case return num * factorial(num - 1 ) // Recursive case } console.log(factorial( 4 )) // 24 Để hiểu hơn, hãy xem Call stack của hàm trên: 4. factorial(1) | return 1 3. factorial(2) | return 2 * factorial(1) 2. factorial(3) | return 3 * factorial(2) 1. factorial(4) | return 4 * factorial(3) Như vậy sau khi hàm dừng recursive thì Call ...