成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

[email protected] 嚴(yán)格模式下 Array.map 的一點(diǎn)問題

xiaoxiaozi / 980人閱讀

摘要:背景是的項目,并且打開了嚴(yán)格模式的情況下大概我的需求是,將中的一個數(shù)組在中進(jìn)行渲染,那么自然就想到了的方法,然后再中直接將數(shù)組轉(zhuǎn)成代碼塊。同樣的,的解構(gòu)賦值,也只是淺拷貝所以說,嚴(yán)格模式下一直再警告我不能修改的值。

背景是 React + [email protected] + antd 的項目,并且打開了嚴(yán)格模式的情況下:

configure({ enforceActions: true })

大概我的需求是, 將store 中的一個數(shù)組(dataSource)在stateless Component中進(jìn)行渲染,那么自然就想到了Array 的 map 方法,然后再JSX中直接將數(shù)組轉(zhuǎn)成JSX 代碼塊。

const wrapperItem = (title, list) => {
  const result = list.map((item, index) => 
    
      {index}
    
    
      {item}
    
  )
  return (
    

{title}

{result}
) }

上面的demo 代碼中的第二個參數(shù)list 會傳入observable 屬性----是一個數(shù)組。

然后瀏覽器狂報錯誤:

[mobx] Since strict-mode is enabled, changing observed observable values outside actions is not allowed. Please wrap the code in an `action` if this change is intended. Tried to modify: [email protected]

然后看一下 下面的簡單代碼排查錯誤吧:

var list = [{"a": 1},{"a": 2}];
var newList = list.map(function(index){
    return index.a += 1;
});
console.log(newList,"newList",list,"list");
// newList 和 list 都改變了。先修改了list的單個key值,再將key值返回,自然就修改了兩個

var list = [{"a": 1},{"a": 2}];
var newList = list.slice(0).map(function(index){
    return index.a += 1;
});
console.log(newList,"newList",list,"list");
// newList 和 list 也都改變了,關(guān)鍵很不理解,明明 list 跟 list.slice(0) 已經(jīng)不是指向同一個數(shù)組,為什么list.slice(0) 修改內(nèi)容還會引發(fā)list 也改變?


// wa ... 
// 難受的一批。。。
// slice() concat() 都是淺拷貝,整個數(shù)組的指向是不同的了,但是,里面的對象的指向是同一個,所以其實(shí)在map里執(zhí)行的函數(shù),操作的對象還是同一個。。。
list.slice(0)[0] === list[0] // truw
list.slice(0) === list // false

同樣的,es6 的解構(gòu)賦值,也只是淺拷貝:

    var a = {b: {c:111},d:{d:2222}}
    var  = a
    b === a.b
    // true

所以說,mobx嚴(yán)格模式下一直再警告我不能修改observable 的值。

  constructor() {
    this.initData()
  }
  @action initData = async () => {

     this.baseInfo = await getBaseInfo()
     this.extractInfo = await getExtractInfo()
     this.extractInfo = await getExtractStatus()

  }

我之前的代碼是這樣的,其實(shí),我覺得連@action 也不要,因為就算在嚴(yán)格模式下constructor函數(shù)中也是可以修改observable中的值的。

那為什么一直報不能在action之外修改observable 屬性的錯誤呢?

action 僅影響當(dāng)前運(yùn)行的函數(shù),而不會影響異步函數(shù),這意味著如果你有setTimeout,promise, then 或 異步的constructor ,在回調(diào)更多的狀態(tài)改變,這些回調(diào)應(yīng)包裝在 runInAction 中。。。。

寫在最后:

我之前真的沒有好好注意這個問題,對于以前沒有任何限制引用值的 set 的時候,我往往只關(guān)心我得到的值(return 出來的)是不是我想要的。。。。

說明我對于什么 slice,concat() 產(chǎn)生一個新的數(shù)組這一個概念的理解,只停留于表面。。。。

我這么菜,不能老是這樣。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/94319.html

相關(guān)文章

  • 【用故事解讀 MobX 源碼(四)】裝飾器 和 Enhancer

    摘要:所以這是一篇插隊的文章,用于去理解中的裝飾器和概念。因此,該的作用就是根據(jù)入?yún)⒎祷鼐唧w的描述符。其次局部來看,裝飾器具體應(yīng)用表達(dá)式是,其函數(shù)簽名和是一模一樣。等裝飾器語法,是和直接使用是等效等價的。 ================前言=================== 初衷:以系列故事的方式展現(xiàn) MobX 源碼邏輯,盡可能以易懂的方式講解源碼; 本系列文章: 《【用故事解...

    maybe_009 評論0 收藏0
  • 這兒有20道大廠面試題等你查收

    摘要:本文挑選了到大廠面試題,大家在閱讀時,建議不要先看我的答案,而是自己先思考一番。構(gòu)造函數(shù)返回值是或,是返回的是種返回的對象。 今年來,各大公司都縮減了HC,甚至是采取了裁員措施,在這樣的大環(huán)境之下,想要獲得一份更好的工作,必然需要付出更多的努力。 本文挑選了20到大廠面試題,大家在閱讀時,建議不要先看我的答案,而是自己先思考一番。盡管,本文所有的答案,都是我在翻閱各種資料,思考并驗證之...

    tianyu 評論0 收藏0
  • mobx學(xué)習(xí)總結(jié)

    摘要:原理分析的核心就是通過觀察某一個變量,當(dāng)該變量產(chǎn)生變化時,對應(yīng)的內(nèi)的回調(diào)函數(shù)就會發(fā)生變化。回調(diào)函數(shù)若依賴外部環(huán)境,則無法進(jìn)行收集很好理解,的回調(diào)函數(shù)在預(yù)執(zhí)行的時候無法到達(dá)那一行代碼,所以收集不到。 Mobx解決的問題 傳統(tǒng)React使用的數(shù)據(jù)管理庫為Redux。Redux要解決的問題是統(tǒng)一數(shù)據(jù)流,數(shù)據(jù)流完全可控并可追蹤。要實(shí)現(xiàn)該目標(biāo),便需要進(jìn)行相關(guān)的約束。Redux由此引出了dispa...

    roundstones 評論0 收藏0
  • JavaScript數(shù)組學(xué)習(xí)記錄_11

    摘要:數(shù)組學(xué)習(xí)記錄是的實(shí)例屬性。對數(shù)組元素進(jìn)行排序,并返回當(dāng)前數(shù)組。返回一個由所有數(shù)組元素組合而成的字符串。為數(shù)組中的每個元素執(zhí)行一次回調(diào)函數(shù)。返回一個數(shù)組迭代器對象,該迭代器會包含所有數(shù)組元素的鍵值對。 JavaScript數(shù)組學(xué)習(xí)記錄 Array.length Array.length 是Array的實(shí)例屬性。返回或設(shè)置一個數(shù)組中的元素個數(shù)。該值是一個無符號 32-bit 整數(shù),并且總是...

    TalkingData 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<