成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Immer如何使用

今天小編給大家分享一下Immer如何使用的相關(guān)知識點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

河池網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)建站從2013年創(chuàng)立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。

Immer本身也得到了廣泛關(guān)注和認(rèn)可,在Redux最新推薦的Redux Toolkit 中就集成了Immer

Immer并不會對原有的狀態(tài)數(shù)據(jù)進(jìn)行直接更改,這樣就保持了不可變性,但是在使用語法上卻是直接賦值,注意如圖所示,直接賦值的對象并不是原有的狀態(tài)數(shù)據(jù),而是另一個(gè)Draft對象。

 const nextState = baseState.slice() // 淺拷貝

 nextState[1] = {

     // 替換元素

     …nextState[1], // 淺拷貝位置1的元素

     done: true // 修改

 }

 nextState.push({title: "Tweet about it"})

假如數(shù)據(jù)結(jié)構(gòu)層次很深,同時(shí)又不想做范式化,因?yàn)橐恍I(yè)務(wù)場景范式化后的數(shù)據(jù)在使用時(shí)也還是要整合起來,不如直接使用樹狀數(shù)據(jù)來的方便,此時(shí)修改數(shù)據(jù)簡直就是噩夢,所以Immer針對的就是這種情況,它僅僅是處理了復(fù)雜數(shù)據(jù)的更新,并不涉及到副作用,以下例子摘自Immer官網(wǎng)

 import produce from "immer"

 const nextState = produce(baseState, draft => {

     draft[1].done = true

     draft.push({title: "Tweet about it"})

 })

可以看到,現(xiàn)在要得到更新后的狀態(tài)非常方便了,但如同剛才所說的一樣,Immer也僅僅只是半自動化,不涉及副作用,所以一般最后我們還是要調(diào)用setState 或者其他的操作來完成最終的業(yè)務(wù)目的。

安裝

 npm install immer

要注意的是如果想要得到額外的支持,還需要調(diào)用一些引入API,同時(shí)打包結(jié)果也會變大

支持 調(diào)用

支持ES5 enableES5()

支持Map和Set數(shù)據(jù)結(jié)構(gòu) enableMapSet()

支持JSON Patch enablePatches()

以上所有都想支持 enableAllPlugins()

用法

 // 在應(yīng)用的入口處

 import {enableMapSet} from "immer"

 enableMapSet()

 // …稍后

 import produce from "immer"

 const usersById_v1 = new Map([

     ["michel", {name: "Michel Weststrate", country: "NL"}]

 ])

 const usersById_v2 = produce(usersById_v1, draft => {

     draft.get("michel")。country = "UK"

 })

 const usersById_v3 = produce(usersById_v1, draft => {

     draft.set("michel", {name: "Michel Weststrate", country: "NL"})

 })

使用produce

Immer的要點(diǎn)就在于produce的使用,它的簽名如下

 produce(currentState, recipe: (draftState) => void): nextState

注意這些名稱

produce

recipe

draftState / draft

producer

…

這些名稱沒法硬翻,或者翻譯后失去味道,只能靠揣摩和感悟

一個(gè)produce的HW代碼如下

 import produce from "immer"

 const baseState = [

     {

         title: "Learn TypeScript",

         done: true

     },

     {

         title: "Try Immer",

         done: false

     }

 ]

 const nextState = produce(baseState, draftState => {

     draftState.push({title: "Tweet about it"})

     draftState[1].done = true

 })

對了,HW不是華為,是Hello World

以上就是“Immer如何使用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站欄目:Immer如何使用
網(wǎng)頁網(wǎng)址:http://jinyejixie.com/article6/jjijig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、網(wǎng)站制作、Google、品牌網(wǎng)站設(shè)計(jì)、定制開發(fā)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)
昭平县| 高碑店市| 宁安市| 奉新县| 玉田县| 广昌县| 岑巩县| 泽州县| 修文县| 紫阳县| 三河市| 苍山县| 瑞丽市| 昌吉市| 彩票| 鸡泽县| 宿迁市| 兴隆县| 玉溪市| 平乐县| 灵璧县| 芜湖县| 峨山| 德阳市| 林西县| 雅江县| 泽州县| 湘潭县| 科技| 金坛市| 竹山县| 宣威市| 澄城县| 堆龙德庆县| 神农架林区| 左权县| 扎鲁特旗| 卢氏县| 德清县| 义马市| 海盐县|