闂傚倸鍊搁崐鎼佸磹閻戣姤鍤勯柤鍝ユ暩娴犳氨绱撻崒娆掑厡缂侇噮鍨跺畷褰掑礈娴g懓搴婂┑鐐村灦閻熝呭姬閳ь剟姊虹粙娆惧創濠殿喓鍊濋幆鍕敍閻愬弶鐎梺鐟板⒔缁垶寮查幖浣圭叆闁绘洖鍊圭€氾拷
80KM濠电姷鏁告慨鐑藉极閸涘﹥鍙忓ù鍏兼綑閸ㄥ倿鏌i幘宕囧哺闁哄鐗楃换娑㈠箣閻愨晜锛堝┑鐐叉▕娴滄繈寮查幓鎺濈唵閻犺櫣灏ㄦΛ姘舵煕閳哄啫浠辨慨濠冩そ濡啫鈽夊顒夋毇婵犵妲呴崑鍛存偡閿曞倸绠為柕濞垮劗閸亪鏌涢弴妤佹珒缂併劌顭峰娲传閸曨厜鐘绘煕閺傚潡鍙勬鐐诧躬瀹曠喖顢栭崣銉х泿闂備浇顫夋刊浠嬪春閺嶎偀鍋撳鐐
闂傚倸鍊搁崐鎼佸磹閻戣姤鍤勯柛顐f礀閸屻劎鎲搁弮鍫澪ラ柛鎰ㄦ櫆閸庣喖鏌曡箛瀣労婵炶尙枪閳规垿鎮╃拠褍浼愰柣搴㈠嚬閸欏啫鐣烽敐鍫㈢杸婵炴垶鐟ч崢鎾绘⒑閸涘﹦绠撻悗姘煎墴閸┾偓妞ゆ巻鍋撻柟鑺ョ矊閳诲酣濮€閵堝棗鈧兘鏌i幋鐐ㄧ細闁告﹢浜跺娲濞戣鲸鈻撻梺鎼炲妽婵炲﹪骞冩ィ鍐╃劶鐎广儱妫涢崢鍛婄箾鏉堝墽鍒版繝鈧柆宥嗗剹闁圭儤顨嗛悡娑㈡倶閻愰鍤欏┑鈥炽偢閺屽秹鎸婃径妯恍﹂柧浼欑秮閺屾盯鈥﹂幋婵囩彯婵炲鍘ч崯鏉戭潖缂佹ɑ濯村瀣凹鐟曞棛绱撻崒姘毙¢柤鍐插閸掓帗绻濆顒€鍞ㄩ悷婊勭矒瀹曠敻寮撮悢缈犵盎闂佸搫鍟崐鍛婄閸撗€鍋撶憴鍕妞わ富鍨舵俊鎾箳閹搭厽鍍甸梺缁樻尭濞撮攱绂掗銏$厸鐎广儰璁查崑鎾诲棘閵夛附鏉搁梻浣虹帛閸旀洖螣婵犲洤鍚归柣鏂跨殱閺€鑺ャ亜閺嶃劎鈯曢悘蹇ラ檮椤ㄣ儵鎮欓懠顒傤啋闂佽桨鐒﹂幑鍥极閹剧粯鏅搁柨鐕傛嫹
闂傚倸鍊搁崐宄懊归崶褏鏆﹂柛顭戝亝閸欏繒鈧娲栧ú锔藉垔婵傚憡鐓涢悘鐐额嚙閸旀岸鏌i妶鍥т壕缂佺粯鐩畷鍗炍熼搹閫涙偅缂傚倷璁查崑鎾斥攽閻樻彃鏆為柛娆忕箲娣囧﹪鎮欐0婵嗘婵炲瓨绮撶粻鏍ь潖閾忚瀚氶柍銉ョ-娴犫晠姊洪崫銉ユ瀾婵炲吋鐟╅幃楣冩倻閼恒儱浜滅紒鐐妞存悂寮查姀锛勭閺夊牆澧界粔顒併亜閺囩喓澧电€规洦鍨堕崺鈧い鎺戝閳锋帡鏌涚仦鍓ф噯闁稿繐鏈妵鍕閻欏懓鍚銈冨灪瀹€绋款嚕娴犲鏁囬柣鎰暩瀹曡埖绻濆閿嬫緲閳ь剚鍔欏畷鎴﹀箻濞n兛绨婚梺瀹犳〃闂勫秹宕戦姀鈶╁亾鐟欏嫭绀€闁靛牊鎮傞獮鍐閵忊€充粧闂佹枼鏅涢崯鐗堢濞嗘挻鈷戦悹鍥ㄧ叀椤庢绱掗悩鑼х€规洘娲樺ḿ蹇涘煘閹傚濠殿喗岣块崢褔鐛Δ鍐<閻庯綆浜跺Ο鈧繝娈垮枓閸嬫捇姊虹紒妯兼喛闁稿鎹囬弻锝夊棘閹稿寒妫﹂梺璇″枦椤骞忛崨顖滈┏閻庯綆鍋嗙粔鐑芥⒑鐠囨彃顒㈤柣鏃戝墴楠炲繘鏁撻敓锟�

Redux VS Redux 工具包 && Redux Thunk VS Redux-Saga-js教程

首页 2024-07-11 18:45:19

简介

在现代 web 特别是在开发过程中 react,有效的管理状态对于构建动态响应应用程序至关重要。状态表示可以随时间变化的数据,如用户输入、获取的数据或任何其他动态内容。如果没有适当的状态管理,应用程序可能会变得难以维护和调试,从而导致 ui 不一致和行为是不可预测的。这是状态管理工具的使用场所,帮助开发人员在其应用程序中有效地维护和操作状态。

当地州

使用 react 的 usestate 钩子在每个组件中管理本地状态。这种方法非常简单,非常适合简单的、特定的组件状态要求。

示例:

import react, { usestate } from 'react';

function counter() {
  const [count, setcount] = usestate(0);

  return (
    <div>
      <p>count: {count}</p>
      <button onclick="{()"> setcount(count   1)}&gt;increment</button>
    </div>
  );
}

用例: 本地状态非常适合小型、独立的组件,不需要由其他组件共享或访问。

上下文api

context api 允许在多个组件之间共享状态,而无需 prop 钻取使其成为更复杂状态共享需求的良好解决方案。

示例:

import react, { createcontext, usecontext, usestate } from 'react';

const themecontext = createcontext();

function themeprovider({ children }) {
  const [theme, settheme] = usestate('light');

  return (
    <themecontext.provider value="{{" theme settheme>
      {children}
    </themecontext.provider>
  );
}

function themedcomponent() {
  const { theme, settheme } = usecontext(themecontext);

  return (
    <div>
      <p>current theme: {theme}</p>
      <button onclick="{()"> settheme(theme === 'light' ? 'dark' : 'light')}&gt;toggle theme</button>
    </div>
  );
}

用例: context api 它对整体状态非常有用,例如,需要由组件树中多个组件访问的主题或用户身份验证。

redux

redux 它是一个状态管理库,提供集中存储,用于管理具有可预测状态转换的全局状态,使用减速器和操作。

示例:

// store.js
import { createstore } from 'redux';

const initialstate = { count: 0 };

function counterreducer(state = initialstate, action) {
  switch (action.type) {
    case 'increment':
      return { count: state.count   1 };
    default:
      return state;
  }
}

const store = createstore(counterreducer);

redux 工具包

redux toolkit 官方推荐使用 redux 该方法简化了样板代码的设置和减少。

示例:

// store.js
import { configurestore, createslice } from '@reduxjs/toolkit';

const counterslice = createslice({
  name: 'counter',
  initialstate: { count: 0 },
  reducers: {
    increment: state =&gt; { state.count  = 1; },
  },
});

const store = configurestore({
  reducer: {
    counter: counterslice.reducer,
  },
});

export const { increment } = counterslice.actions;
export default store;

local state、context api、redux 和 redux toolkit 之间的区别

- 本地状态及上下文 api:
局部状态仅限于单个组件,使其成为小型、独立状态需求的理想选择。另一方面,context api 允许跨多个组件共享状态,以避免 prop 钻探。

- redux 与 redux 工具包:
redux 它提供了一种具有大量模型的传统状态管理方法。 redux toolkit 使用 createslice 和 createasyncthunk 其他实用程序简化了流程,使编写干净、可维护的代码更加容易。

中间件:

redux 中间部件作为调度操作,达到减速器之间的强大扩展点。 redux thunk 和 redux saga 等中间件可以实现处理异步操作和管理副作用等高级功能。

中间件的必要性
管理中间件 redux 异步操作和副作用在应用程序中非常重要。它们有助于保持操作创建者和减速器的纯度,没有副作用,从而产生更干净、更容易维护的代码。

1. redux thunk

redux thunk 将异步调度简化,允许操作创建者返回函数而不是普通对象。

示例:

const fetchdata = () =&gt; async dispatch =&gt; {
  dispatch({ type: 'fetch_data_start' });
  try {
    const data = await fetch('/api/data').then(res =&gt; res.json());
    dispatch({ type: 'fetch_data_success', payload: data });
  } catch (error) {
    dispatch({ type: 'fetch_data_failure', error });
  }
};

用例: redux thunk 适用于简单的异步操作,如从 api 获取数据。

2. redux 传奇

redux saga 利用生成器函数管理的复杂副作用,为异步逻辑提供了更加结构化和可管理的方法。

示例:

import { call, put, takeEvery } from 'redux-saga/effects';

function* fetchDataSaga() {
  yield put({ type: 'FETCH_DATA_START' });
  try {
    const data = yield call(() =&gt; fetch('/api/data').then(res =&gt; res.json()));
    yield put({ type: 'FETCH_DATA_SUCCESS', payload: data });
  } catch (error) {
    yield put({ type: 'FETCH_DATA_FAILURE', error });
  }
}

function* watchFetchData() {
  yield takeEvery('FETCH_DATA_REQUEST', fetchDataSaga);
}

用例: redux saga 非常适合处理复杂的异步工作流程,如涉及多个步骤、重试或复杂条件逻辑的工作流程。

redux thunk 和 redux saga 之间的区别

- redux thunk:
最适合更简单、更直接的异步操作。它允许动作创建者返回函数,并且易于理解和实现。

- redux saga:
最适合更复杂和结构化的异步工作流程。它使用生成器函数来处理副作用,并提供更强大但更复杂的异步逻辑管理解决方案。

结论

有效的状态管理可扩展和可维护 react 应用程序非常重要。虽然地方状态和 context api 更简单的用例可以很好的满足,但是 redux 和 redux toolkit 为大型应用程序提供了强有力的解决方案。像 redux thunk 和 redux saga 这些状态管理工具通过处理异步操作和副作用进一步加强,每个工具都满足了应用逻辑中不同复杂性的需求。

除了这些工具,还有其他工具可以与之相匹配 react 共同使用的状态管理库包括:

recoil: 专为 react 设计的状态管理库提供细粒度控制和轻松的跨组件状态共享。它简化了状态管理,使用原子和选择器分别使用状态和衍生状态。
mobx: 注重简单性和可观察性,使其更容易处理复杂的表单和实时更新。 mobx 它提供了一个更具反应性的编程模型,可以自动跟踪状态变化并相应更新 ui。
zustand: 小型、快速、可扩展的状态管理解决方案。它使用钩子来管理状态,并提供一个简单的 api 创建存储和更新状态。
选择正确的工具取决于应用程序的具体需求和复杂性。了解每个工具的优点和用例可以在你身上 react 实现更高效、更可维护的状态管理。

以上是Redux VS Redux 工具包 && Redux Thunk VS Redux-关于Saga的详细信息,请关注其他相关文章!


p
SEO闂傚倸鍊搁崐鎼佸磹妞嬪海鐭嗗ù锝堟缁€濠傗攽閻樻彃鈧绱撳杈ㄥ枑闊洦娲橀~鏇㈡煟閹邦剦鍤熺紒鈾€鍋撻梻浣规偠閸庢粓宕堕…鎺旇埞婵犵數濮烽弫鎼佸磻濞戞鐔哥節閸愵亶娲稿┑鐘诧工閻楀﹦鈧艾鎳橀弻锝夊棘閸喗鍊梺缁樻尪閸庣敻寮婚敐澶婂嵆闁绘劖绁撮崑鎾诲捶椤撴稑浜炬慨妯煎亾鐎氾拷
闂傚倸鍊搁崐鎼佸磹妞嬪海鐭嗗〒姘e亾妤犵偞鐗犻、鏇㈡晜閽樺缃曢梻浣虹《閸撴繈鎮疯閹矂骞樼紒妯衡偓鍨箾閹寸儐浼嗛柟杈剧畱閻鐓崶銊р姇闁绘挾鍠栭弻锟犲礃閵娿儮鍋撻崫銉︽殰闁割偅娲橀埛鎺楁煕鐏炶鈧洟鎮橀敃鍌涚厸閻忕偟鍋撶粈鍐磼缂佹ḿ顬兼い锔界叀閺岋繝宕奸銏犫拫閻庤娲滄繛鈧柟顔规櫇缁辨帒螣闁垮顏瑰┑鐘垫暩閸嬬姷浜稿▎鎴濆灊妞ゆ牗绮嶉鑺ョ箾閹存瑥鐏柣鎾寸懇閺屾盯骞嬪▎蹇婂亾閺嶎偀鍋撳鐐
闂傚倸鍊搁崐椋庣矆娓氣偓楠炴牠顢曚綅閸ヮ剦鏁冮柨鏇楀亾闁汇倗鍋撶换婵囩節閸屾稑娅i梺鎼炲妽缁诲牓鐛弽顬ュ酣顢楅埀顒佷繆婵傚憡鐓熼柟鎯ь嚟缁犳捇鏌嶇憴鍕伌鐎规洘甯掗埞鍐箻閾忣偉纭€闂侀€炲苯澧柤褰掔畺钘濋梺顒€绉撮悞鍨亜閹哄棗浜剧紓浣哄Т缁夌懓鐣烽弴銏$劶鐎广儱鎳愰悿鍥煙閸忓吋鍎楅柣鎾愁槺缁辩偤寮介鐔哄帾闂佸壊鍋呯换宥呂hぐ鎺撶厽闁规儳鐡ㄧ粈瀣煛鐏炶濡奸柍瑙勫灴瀹曞崬螖娴h鍞叉繝鐢靛Х椤d粙宕滃┑瀣畺闁稿瞼鍋涢拑鐔衡偓骞垮劚閻楁粌顬婇妸鈺傗拺缂佸娉曠粻鑼磼鐎n偄鐏存繝鈧笟鈧娲箹閻愭彃濮夐梺鍝勬噺缁矂鎮鹃悜钘夌煑濠㈣泛鐬奸鏇㈡⒑缁洖澧查柨姘舵煟韫囧﹥娅婇柡宀嬬秮椤㈡﹢鎮㈤悜妯烘珣闂備礁鐤囬~澶愬垂閸фぜ鈧礁鈽夊Ο婊勬閸┾偓妞ゆ帊鑳堕々鑼磽瀹ュ洤鐦查梻鍌氬€峰ù鍥敋瑜嶉~婵嬫晝閸岋妇绋忔繝銏e煐閸旀洜绮婚弽顓熺厱妞ゆ劧绲剧粈鈧紒鐐劤濞尖€愁潖濞差亶鏁嗛柍褜鍓涚划鏃堝箻椤旇棄鍓瑰┑掳鍊曢幊蹇涙偂閵夆晜鐓熼柡鍥╁仜閳ь剙婀遍埀顒佺啲閹凤拷
濠电姷鏁告慨鐑藉极閹间礁纾婚柣鎰惈閸ㄥ倿鏌涢锝嗙缂佺姳鍗抽弻鐔虹磼閵忕姵鐏堢紒鐐劤椤兘寮婚悢鐓庣鐟滃繒鏁☉銏$厓闂佸灝顑呴悘锔剧磼缂佹ḿ娲寸€规洖宕灒闁告繂瀚闂傚倷绀侀幖顐︻敄閸℃稒鍋¢柍鍝勬噹閽冪喖鏌i弬鎸庢喐闁荤喎缍婇弻娑⑩€﹂幋婵囩亪濡炪値鍋勫ú顓㈠箖濡も偓閳绘捇宕归鐣屼簴闂備礁鎲¢弻銊︻殽閹间礁鐓″鑸靛姈閸嬨劎绱掔€n亞浠㈢紒鎰☉椤啴濡堕崱娆忣潷缂備緡鍠氭繛鈧€规洦鍨伴悾婵嬪焵椤掑倹顫曢柟鎹愵嚙绾惧吋绻涢崱妯虹劸婵″樊鍠栭—鍐Χ閸℃浠撮梺纭呮珪閿曘垽濡存笟鈧浠嬵敇閻愰潧鈧偛顪冮妶鍡楃瑨妞わ缚鍗冲鎻掆堪閸愮偓瀵岄梺闈涚墕濡绮幒妤佸€垫慨妯煎帶婢ф挳鏌熼姘冲閾绘牠鏌涘☉鍗炴灓闁告瑥妫濆铏圭磼濡崵顦ラ梺绋匡工濠€閬嶅焵椤掍胶鍟查柟鍑ゆ嫹
C闂傚倸鍊搁崐鎼佸磹閻戣姤鍤勯柛顐f礀绾惧潡鏌i姀鈶跺綊鎮块悙顒傜瘈濠电姴鍊搁弳鐔割殽閻愬瓨宕岄柡灞剧椤﹁櫕銇勯妸銉﹀殗鐎规洖缍婂畷鎺楁倷閼碱剦鍟囬梺鍝勵槸閻楀棙鏅舵禒瀣畺闁稿繘妫跨换鍡樸亜閹伴潧浜滈柣蹇ョ節閺屾洟宕惰椤忣厽銇勯姀鈩冪妞ゃ垺娲熸慨鈧柨娑樺婢规洜绱撻崒姘偓椋庢媼閺屻儱纾婚柟鐐墯閻斿棝鎮规潪鎷岊劅闁稿孩鍨圭槐鎺楁偐閼姐倗鏆梺鍝勭灱閸犳牠鐛幋锕€绠涙い鎾跺Т濞懷囨⒒娓氣偓濞艰崵寰婇懖鈺佸灊婵炲棙鎸搁拑鐔兼煟閺冨倵鎷¢柡浣革功閻ヮ亪顢橀悙鍙壭╂繛鏉戝悑閸旀洟鈥旈崘顔嘉ч柛鈩冡缚閸欏棛绱撴担铏瑰笡閽冨崬菐閸パ嶈含闁诡喗绮撻幐濠冪珶閳瑰灝濮傞柡灞炬礃瀵板嫰宕煎┑鍡椥戞繝纰樻閸ㄤ粙骞忛敓锟�