React中的另一種狀態(tài)管理方案Valtio

React中的狀態(tài)管理是開發(fā)人員需要解決的問題。 總有一些新庫給你選擇谬以,而選擇合適的庫可能是一項困難的工作

狀態(tài)管理一直是React中開發(fā)人員需要解決的問題盯串,如何有條理的組織數(shù)據(jù)戴陡,如何快速的在項目中集成,這些都是我們做項目時選擇技術的標準绰更。

Redux一直是我們react項目中不二的狀態(tài)管理插件,但是redux的配置以及各種插件的安裝一直是很多人員頭疼的一個問題,太麻煩了。但是隨著ReduxToolkit的出現(xiàn),確實解決了這個問題邑雅,直接安裝,就不再需要繼續(xù)安裝各類其他插件妈经,直接上手就能用淮野,簡單方便。但是很多時候吹泡,我們的項目可能根本不需要這么笨重的插件骤星,雖然redux很好,但是畢竟這么多年過去了爆哑,一代新人換舊人洞难。前端這個大坑中,總會出現(xiàn)新的技術揭朝、框架來埋葬那些老家伙队贱。

代理

Proxy對象用于創(chuàng)建一個對象的代理,從而實現(xiàn)基本操作的攔截和自定義(如屬性查找潭袱、賦值柱嫌、枚舉、函數(shù)調用等)屯换。

自ES6版本以來编丘,我們在JavaScript中有代理。 代理接收兩個參數(shù):

target - 要代理的原始對象

handler - 定義對象的操作

這是我們如何使用JavaScript創(chuàng)建代理的方式:

const handler = {

? get: function (obj, prop) {

? ? return prop in obj ? obj[prop] : 37;

? },

};

const p = new Proxy({}, handler);

p.a = 1;

p.b = undefined;

console.log(p.a, p.b); // 1, undefined

console.log('c' in p, p.c); // false, 37

Valtio

Valtio是一個用于對React和JavaScript應用程序簡單的代理狀態(tài)的庫彤悔。它使用了js中Proxy這個語法嘉抓,能讓我們可以非常方便的在react中集成狀態(tài)管理功能。

npminitvite@latest#創(chuàng)建react項目npmivaltio#進入項目晕窑,安裝依賴

我們需要做的是包裝我們的狀態(tài)對象抑片,然后我們可以在我們的應用程序中的任何地方進行改變:

import{proxy}from'valtio';typeIStore={count:number;list:Item[];};// 定義數(shù)據(jù),使用proxy進行包括修飾

conststore=proxy<IStore>({count:1,list:[],});/**

* 改變數(shù)據(jù)

* @param step

*/exportconstcountPlus=(step:number)=>{store.count+=step;};/**

* 新增數(shù)據(jù)到列表

* @param txt

*/exportconstaddToList=(txt:string)=>{store.list.push({id:Date.now(),txt,});};exportdefaultstore;

定義好的數(shù)據(jù)直接在組件中進行引入就能使用杨赤,useSnapshot可以獲取我們定義好的狀態(tài)數(shù)據(jù)蓝丙,使用之后在組件中就是一個響應式的效果,只要數(shù)據(jù)改變了組件就會直接進行更新

import{useSnapshot}from'valtio';importstore,{countPlus}from'../store';functionCounter(){const{count}=useSnapshot(store);return(<div><h1>計數(shù)器--{count}</h1><buttononClick={()=>{countPlus(2);}}>改變</button></div>);}exportdefaultCounter;

valtio簡單直接望拖,充分使用了proxy這個對象,簡單粗暴的實現(xiàn)react項目的狀態(tài)管理挫鸽。在一些小型項目中是一個不錯的選擇说敏。當然當然大家還是需要在項目中努力做好自己代碼結構的組織方便后去數(shù)據(jù)的維護。

├──index.html├──package-lock.json├──package.json├──public│└──vite.svg├──readme.md├──src│├──@types││└──app.d.ts│├──App.css│├──App.tsx│├──assets││└──react.svg│├──components││├──Counter.tsx││├──List│││├──index.tsx│││└──list-input.tsx││├──Movies.tsx││└──ShowCounter.tsx│├──index.css│├──main.tsx│├──store││├──features│││└──movie.ts││└──index.ts│└──vite-env.d.ts├──tsconfig.json├──tsconfig.node.json└──vite.config.ts

store丢郊,目錄存儲valtio的數(shù)據(jù)盔沫。index.ts做為入口医咨,可以引入其他的子節(jié)點數(shù)據(jù)

store/features,目錄可以根據(jù)功能做拆分處理架诞。每一個功能對應一個文件

比如此處我的movie.ts文件的內容如下

// store/features/movie.ts

import{proxy}from'valtio';// 進行分割

exportconstmovie=proxy({movies:[],});exportconstloadMovieData=async()=>{constres=awaitfetch('https://pcw-api.iqiyi.com/search/recommend/list?channel_id=2&data_type=1&mode=11&page_id=2&ret_num=48&session=ffad98ae609f650afe4b60e205948ac1&three_category_id=15;must').then((data)=>data.json());movie.movies=res.data.list;};

完成的store/index.ts文件如下

import{proxy}from'valtio';import{movie}from'./features/movie';/**

* 定義數(shù)據(jù)

*/conststore=proxy<IStore>({count:1,list:[],movie,// 引入拆分好的文件

});/**

* 改變數(shù)據(jù)

* @param step

*/exportconstcountPlus=(step:number)=>{store.count+=step;};/**

* 新增數(shù)據(jù)到列表

* @param txt

*/exportconstaddToList=(txt:string)=>{store.list.push({id:Date.now(),txt,});};exportdefaultstore;

而我組件中如果要獲取數(shù)據(jù)拟淮,可以直接拿來用

// components/Movie.tsx

import{useEffect}from'react';import{useSnapshot}from'valtio';importstorefrom'../store';import{loadMovieData}from'../store/features/movie';functionMovies(){const{movie}=useSnapshot(store);// useSnapshot取數(shù)據(jù)

// console.log(movie);

useEffect(()=>{loadMovieData();},[]);return(<divclassName='movies'><ul>{movie.movies.map((item:any)=>(<likey={item.albumId}>{item.name}</li>))}</ul></div>);}exportdefaultMovies;

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市谴忧,隨后出現(xiàn)的幾起案子很泊,更是在濱河造成了極大的恐慌,老刑警劉巖沾谓,帶你破解...
    沈念sama閱讀 211,743評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件委造,死亡現(xiàn)場離奇詭異,居然都是意外死亡均驶,警方通過查閱死者的電腦和手機昏兆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來妇穴,“玉大人爬虱,你說我怎么就攤上這事√谒” “怎么了跑筝?”我有些...
    開封第一講書人閱讀 157,285評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長携狭。 經常有香客問我继蜡,道長,這世上最難降的妖魔是什么逛腿? 我笑而不...
    開封第一講書人閱讀 56,485評論 1 283
  • 正文 為了忘掉前任稀并,我火速辦了婚禮,結果婚禮上单默,老公的妹妹穿的比我還像新娘碘举。我一直安慰自己,他們只是感情好搁廓,可當我...
    茶點故事閱讀 65,581評論 6 386
  • 文/花漫 我一把揭開白布引颈。 她就那樣靜靜地躺著,像睡著了一般境蜕。 火紅的嫁衣襯著肌膚如雪蝙场。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,821評論 1 290
  • 那天粱年,我揣著相機與錄音售滤,去河邊找鬼。 笑死,一個胖子當著我的面吹牛完箩,可吹牛的內容都是我干的赐俗。 我是一名探鬼主播,決...
    沈念sama閱讀 38,960評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼弊知,長吁一口氣:“原來是場噩夢啊……” “哼阻逮!你這毒婦竟也來了?” 一聲冷哼從身側響起秩彤,我...
    開封第一講書人閱讀 37,719評論 0 266
  • 序言:老撾萬榮一對情侶失蹤叔扼,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后呐舔,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體币励,經...
    沈念sama閱讀 44,186評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,516評論 2 327
  • 正文 我和宋清朗相戀三年珊拼,在試婚紗的時候發(fā)現(xiàn)自己被綠了食呻。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,650評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡澎现,死狀恐怖仅胞,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情剑辫,我是刑警寧澤干旧,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站妹蔽,受9級特大地震影響椎眯,放射性物質發(fā)生泄漏。R本人自食惡果不足惜胳岂,卻給世界環(huán)境...
    茶點故事閱讀 39,936評論 3 313
  • 文/蒙蒙 一编整、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧乳丰,春花似錦掌测、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,757評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至什燕,卻和暖如春粘勒,著一層夾襖步出監(jiān)牢的瞬間屎即,已是汗流浹背仲义。 一陣腳步聲響...
    開封第一講書人閱讀 31,991評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留埃撵,地道東北人。 一個月前我還...
    沈念sama閱讀 46,370評論 2 360
  • 正文 我出身青樓虽另,卻偏偏與公主長得像,于是被迫代替她去往敵國和親捂刺。 傳聞我的和親對象是個殘疾皇子谣拣,可洞房花燭夜當晚...
    茶點故事閱讀 43,527評論 2 349

推薦閱讀更多精彩內容