重寫shouldComponentUpdate方法
import React, { Component } from "react"; import { is } from "immutable"; export default class PureComponent extends Component { shouldComponentUpdate(newProps, newState) { let oldState = this.state || {}; let oldProps = this.props || {}; newState = newState ? newState : {}; if (Object.keys(oldState).length !== Object.keys(newState).length || Object.keys(oldProps).length !== Object.keys(newProps).length) { return true; } //屬性的個數長度不一樣更新,屬性不相同更新,否則不更新 for (let key in newState) { if (!is(newState[key], oldState[key])) { return true; } } for (const key in newProps) { if (!is(oldProps[key], newProps[key])) { return true; } } return false; } }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/109570.html
摘要:的優勢保證不可變每次通過操作的對象都會返回一個新的對象豐富的性能好通過字典樹對數據結構的共享的問題與原生交互不友好通過生成的對象在操作上與原生不同,如訪問屬性,。 Immutable.js Immutable的優勢 1. 保證不可變(每次通過Immutable.js操作的對象都會返回一個新的對象) 2. 豐富的API 3. 性能好 (通過字典樹對數據結構的共享) Immutab...
摘要:為什么你要在中使用熟悉的都應該知道,是一個的框架,為了解決更新的問題,使用了,通過修改,來實現高效的更新??偨Y就是使用通過使用,可以讓我們更容易的去處理緩存回退數據變化檢測等問題,簡化我們的開發。 簡單的來講,immutable.js通過structural sharing來解決的性能問題。看看immutable.js是如何做的當我們發生一個set操作的時候,immutable.js會...
摘要:插件允許我們在的語法中使用在傳遞數據時,可以通過進一步提升組件的渲染性能,是針對可變對象和不可變對象所做的折衷。使用之后,僅僅改變狀態了的組件及其父組件被重新渲染。 1 前言 網頁性能最大的限制因素是瀏覽器重繪(reflow)和重排版(repaint),React的虛擬DOM就是為了盡可能減少瀏覽器的重繪和重排版,從React的渲染過程看,避免不必要的渲染可以進一步提高性能。 2 Pu...
摘要:是一個前端頁面制作工具,方便產品,運營和視覺的同學迅速開發簡單的前端頁面,從而可以解放前端同學的工作量。支持恢復現場功能關閉頁面配置不丟失支持操作。提供了一個方法,用于的拆分。就是發出的通知,表示應該要發生變化了。 pagemaker是一個前端頁面制作工具,方便產品,運營和視覺的同學迅速開發簡單的前端頁面,從而可以解放前端同學的工作量。此項目創意來自網易樂得內部項目nfop中的page...
閱讀 2778·2021-11-23 09:51
閱讀 3534·2021-10-08 10:17
閱讀 1269·2021-10-08 10:05
閱讀 1321·2021-09-28 09:36
閱讀 1841·2021-09-13 10:30
閱讀 2183·2021-08-17 10:12
閱讀 1678·2019-08-30 15:54
閱讀 2009·2019-08-30 15:53