国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

React-native中頁面卸載后setState出現警告的解決辦法

verano / 3159人閱讀

摘要:在使用開發時經常出現這個警告這個警告是因為出現在異步網絡請求返回時頁面已經卸載了,此時仍然會執行的代碼導致的,有很多解決辦法,一般就是加個變量來判斷是否卸載,但是這樣挺麻煩的在每個頁面都添加,我們可以用高階組件來復用邏輯我們可以定義一個

1.在使用react-native開發時經常出現這個警告:
Warning: setState(...): Can only update a mounted or mounting component. This usually means you called setState() on an unmounted component. This is a no-op. Please check the code for the xxx component
這個警告是因為出現在異步網絡請求返回時頁面已經卸載了,此時仍然會執行setState的代碼導致的,有很多解決辦法,一般就是加個isMount變量來判斷是否卸載,但是這樣挺麻煩的在每個頁面都添加,我們可以用高階組件來復用邏輯
2.我們可以定義一個ts模塊

import *as React from "react"
const SafeSetState = function

(WrappedComponent:React.ComponentClass

) { return class SafeComponent extends WrappedComponent{ private isMount:boolean componentDidMount(){ this.isMount=true if(super.componentDidMount){ super.componentDidMount() } } componentWillUnmount(){ this.isMount=false } setState(state,callback?){ if(this.isMount){ super.setState(state,callback) } } } }; export default SafeSetState

我們這種高階組件方式叫反向繼承,我們添加一個isMount屬性,在setState時判斷一下裝填就OK了

其實還有其他高階解決辦法,可以參考這個大神的文章從一次react異步setState引發的思考

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/99918.html

相關文章

  • React和React-native踩坑記

    摘要:坑請求跨域問題使用時,其中的已經默默幫你做了很多事,都幫你配置好了所以你發現你找不到相關的配置文件。放到服務器上仍然是空白的無法訪問。原來是因為路徑問題,簡單配置一下即可。上文提到過已經幫我們做好了很多事,方便在此,麻煩也在此。 react坑: 1、fetch請求cookie跨域問題使用creat-react-app時,其中的react-script已經默默幫你做了很多事,都幫你配置好...

    yck 評論0 收藏0
  • 「譯」setState如何知道它該做什么?

    摘要:本文翻譯自原作者如果有任何版權問題,請聯系當你在組件中調用時,你覺得會發生什么當然,會用這條狀態重新渲染組件并且更新匹配到的,然后返回元素。如果你之前使用過一些渲染器比如說,你可能知道在頁面中使用超過一個渲染器是沒什么問題的。 本文翻譯自:How Does setState Know What to Do?原作者:Dan Abramov 如果有任何版權問題,請聯系shuirong199...

    OldPanda 評論0 收藏0
  • ReactNative開發筆記(持續更新...)

    摘要:,已過期,請使用代替。解決方案安卓增加屬性并設置為官方解釋當圖片實際尺寸和容器樣式尺寸不一致時,決定以怎樣的策略來調整圖片的尺寸。 本文均為RN開發過程中遇到的問題、坑點的分析及解決方案,各問題點之間無關聯,希望能幫助讀者少走彎路,持續更新中... (2019年3月29日更新) 原文鏈接:http://www.kovli.com/2018/06/... 作者:Kovli - 如何在原生...

    浠ラ箍 評論0 收藏0

發表評論

0條評論

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