浠€涔堟槸鐘舵€佺鐞嗭紵鈥滅姸鎬佲€濇槸鎻忚堪搴旂敤绋嬪簭褰撳墠琛屼负鐨勪换浣曟暟鎹€傝繖鍙兘鍖呮嫭璇稿鈥滀粠鏈嶅姟鍣ㄨ幏鍙栫殑瀵硅薄鍒楄〃鈥濄€佲€滃綋鍓嶉€夋嫨鐨勯」鐩€濄€佲€滃綋鍓嶇櫥褰曠敤鎴风殑鍚嶇О鈥濆拰鈥滄妯″紡鏄惁鎵撳紑锛熲€濈瓑鍊笺€備紬鎵€鍛ㄧ煡锛屽湪寮€鍙戜竴涓鏉傚簲鐢ㄧ殑杩囩▼涓紝涓€涓ソ鐨勭姸鎬佺鐞嗘柟妗堟槸蹇呬笉鍙皯鐨勩€備笉浠呭彲浠ユ彁楂樼爺鍙戞晥鐜囷紝杩樺彲浠ラ檷浣庣爺鍙戝拰缁存姢鎴愭湰銆傞偅涔堢姸鎬佺鐞嗘柟妗堥偅涔堝锛屽畠浠箣闂存湁浠€涔堝尯鍒憿锛熸垜浠浣曢€夋嫨閫傚悎褰撳墠搴旂敤鐨勮В鍐虫柟妗堬紵鏈湡鎴戜滑灏嗕富瑕佸React甯歌鐨勭姸鎬佺鐞嗘柟妗堣繘琛屽姣斿垎鏋愶紝甯屾湜瀵瑰悇浣嶇湅瀹樻湁鎵€甯姪銆俁eact鐘舵€佺鐞嗘柟妗堜粙缁峢ookscontextreact-reduxmobxzustandjotairecoilvaltio鏂规瀵规瘮妗嗘灦鍘熺悊浼樼己鐐筯ookscontext鍩轰簬reacthook锛屽紑鍙戣€呭彲浠ュ疄鐜板唴閮?澶栭儴瀛樺偍1.绠€鍗曟槗鐢?br/>2.鏃犻渶鍙傝€冪涓夋柟搴擄紝浣撶Н鏈€灏?br/>3.鏀寔瀛樺偍鍏ㄥ眬鐘舵€侊紝浣嗕笉鎺ㄨ崘鍦ㄥ鏉傚簲鐢ㄤ腑浣跨敤
4.涓嶄緷璧栦簬react涓婁笅鏂囷紝鍙互鍦ㄧ粍浠跺璋冪敤锛堝湪澶栭儴瀛樺偍鐨勬儏鍐典笅锛?銆佸綋context鍊兼敼鍙樻椂锛屾墍鏈夊湪杩欎釜context涓娇鐢ㄧ殑Component閮戒細琚噸鏂版覆鏌撱€傚熀浜庡唴瀹圭淮鎶ょ殑妯″潡瓒婂锛屽奖鍝嶈寖鍥村氨瓒婂ぇ銆?br/>2.渚濊禆ContextProvider鍖呰浣犵殑搴旂敤锛屼慨鏀箂tore鏃犳硶瑙﹀彂搴旂敤椤跺眰娓叉煋锛圓pp.tsx灞傦級
3.鍙梪i妗嗘灦绾︽潫锛坮eact锛?br/>4.DependencyHooks璋冪敤react-reduxFlux鎬濇兂锛屽彂甯?璁㈤槄妯″紡锛岄伒寰嚱鏁板紡缂栫▼锛屽閮ㄥ瓨鍌?.涓嶄緷璧栦簬react涓婁笅鏂囷紝鍙互鍦ㄧ粍浠跺閮ㄨ皟鐢?br/>2.鏀寔鍏ㄥ眬鐘舵€佸瓨鍌?br/>3.Redux鏈韩鏄竴涓€氱敤鐘舵€佺殑瑙e喅鏂规1.蹇冩櫤妯″瀷闇€瑕佷竴浜涙椂闂存潵鐞嗚В锛屽挨鍏舵槸褰撲綘涓嶇啛鎮夊嚱鏁板紡缂栫▼鐨勬椂鍊?br/>2.渚濋潬ContextProvider鏉ュ寘瑁呬綘鐨勫簲鐢紝淇敼store涓嶈兘鍦ㄥ簲鐢ㄧ▼搴忕殑椤堕儴锛圓pp.tsx灞傜骇锛夎Е鍙戞覆鏌?br/>3.鍙楅檺浜巙i妗嗘灦锛坮eact锛塵obx瑙傚療鑰呮ā寮?鏁版嵁鎴祦锛屽閮ㄥ瓨鍌?.浣跨敤鏂逛究锛屽叆闂ㄩ棬妲涗綆
2.涓嶄緷璧杛eact涓婁笅鏂囷紝鍙互鍦ㄧ粍浠跺璋冪敤
br/>3.鏀寔瀛樺偍鍏ㄥ眬鐘舵€?br/>4.閫氱敤鐘舵€佽В鍐虫柟妗?.鍙橀噺鐘舵€佹ā鍨嬶紝鍦ㄦ煇浜涙儏鍐典笅鍙兘浼氬奖鍝嶈皟璇?br/>2.闄や簡姣旇緝澶х殑灏哄澶栵紝鍙﹀锛屼綔鑰呬笉鎰熻鐩墠鏈変粈涔堟槑鏄剧殑涓嶈冻锛?.99MzustandFlux鎬濊矾锛岃瀵熻€呮ā寮忥紝澶栭儴瀛樺偍1.杞婚噺绾э紝鏄撶敤锛屽叆闂ㄩ棬妲涗綆
2.涓嶄緷璧杛eact涓婁笅鏂囷紝鍙互鍦ㄧ粍浠跺璋冪敤
3.鏀寔瀛樺偍鍏ㄥ眬鐘舵€?br/>4.閫氱敤鐘舵€佽В鍐虫柟妗?.妗嗘灦鏈韩涓嶆敮鎸乧omputed灞炴€э紝浣嗘槸computed鍙互鍩轰簬涓棿浠舵満鍒剁敤灏戦噺浠g爜闂存帴瀹炵幇锛屾垨鑰呭熀浜庣涓夋柟搴搝ustand-computed瀹炵幇
jotai鍩轰簬reacthook锛屽唴閮ㄥ瓨鍌?.浣跨敤绠€鍗?br/>2.缁勪欢绮掑害瓒婄粏锛孞otai鎬ц兘瓒婂ソ
3.鏀寔瀛樺偍鍏ㄥ眬鐘舵€?.渚濊禆reactcontext锛屼笉鑳藉湪澶栭儴璋冪敤component锛岀浉瀵规潵璇磟ustand鍦╮eact鐜涔嬪鍜屽叏灞€鑳芥洿濂界殑宸ヤ綔
2.subjecttouiframeworkconstraint(react)recoiladvancedversionjotai锛屽熀浜巖eacthook+providercontext锛屽唴閮ㄥ瓨鍌ㄤ細姣攋otai閲嶄竴浜涳紝浣嗘槸鎬濊矾鍩烘湰涓€鏍凤紝鏈変竴浜沯otai涓嶆敮鎸佺殑鐗规€у拰API锛屾瘮濡?
1.鐩戝惉store鍙樺寲
2.鏇村鐨勫師瀛愭搷浣淎PI锛屾洿澶氱殑缂栫▼鍙兘鎬э紝鏇村鐨勪箰瓒c€傚畠鍏锋湁jotai鐨勬墍鏈夌己鐐癸紝涓巎otai鐩告瘮锛?br/>1.浣跨敤recoil闇€瑕?RecoilRoot>鍖呰9搴旂敤绋嬪簭
2.鍐欎竴涓猻elector浼氬緢澶嶆潅銆俈altio鍩轰簬鏁版嵁鍔寔鍜屽閮ㄥ瓨鍌?.浣跨敤绠€鍗曪紝鍍弇obx锛堝儚vue锛変竴鏍风殑缂栫▼浣撻獙
2.鏀寔瀛樺偍鍏ㄥ眬鐘舵€?br/>3.涓嶄緷璧栦簬react涓婁笅鏂囷紝鍙互鍦ㄥ閮ㄨ皟鐢ㄧ粍浠?br/>4.閫氱敤鐘舵€佽В鍐虫柟妗?.鍙彉鐘舵€佹ā鍨嬶紝鍦ㄦ煇浜涙儏鍐典笅鍙兘浼氬奖鍝嶈皟璇?br/>2.鐩墠绗旇€呰繕娌℃湁鍙戠幇鍏朵粬鐗瑰埆澶х殑缂虹偣銆傛垜涓汉鐚滄祴锛屼箣鎵€浠tars灏戜簬zustand锛屾槸鍥犱负valtio鐨勬暟鎹弻鍚戠粦瀹氭€濊矾鍜宺eact鏈夊啿绐丼ourcehookscontext1.浣跨敤reacthooks+context鏂逛究蹇嵎鐨勭姸鎬佺鐞?.浣跨敤reacthooks+context鏋勫缓redux杩涜鐘舵€佺鐞唕eact-reduxmobximportReactfrom"react"importReactDOMfrom"react-dom"import{makeAutoObservable}from"mobx"import{observer}from"mobx-react"//鐘舵€佸拰鐩稿叧浜嬩欢classTimer{secondsPassed=0constructor(){makeAutoObservable(this)}increase(){this.secondsPassed+=1}reset(){this.secondsPassed=0}}constmyTimer=newTimer()//鏋勫缓涓€涓浉褰撳ぇ鐨勭粍浠禼onstTimerView=observer(({timer})=>({bears}aroundhere...
}//瑙﹀彂鏇存柊鍑芥暟Controls(){constincreasePopulation=useBearStore((state)=>state.increasePopulation)return{count}
)}recoilconstfontSizeState=atom({key:'fontSizeState',default:14,});鍑芥暟FontButton(){const[fontSize,setFontSize]=useRecoilState(fontSizeState);return(
