Learning React(12.React不要なレンダリングを除去)
17967 ワード
1.不要なレンダリングを避ける
01.renderメソッドの正体
02.render呼び出しの最適化
data:image/s3,"s3://crabby-images/b60b5/b60b5b7a892734aafcc5c56ec71616f9b4ae3462" alt=""
03.render呼び出しについて
-1. MenuContainer.js
import React, { Component } from "react";
import MenuButton from "./MenuButton";
import Menu from "./Menu";
class MenuContainer extends Component {
constructor(props) {
super(props);
this.state = {
visible: false,
};
this.handleMouseDown = this.handleMouseDown.bind(this);
this.toggleMenu = this.toggleMenu.bind(this);
}
handleMouseDown(e) {
this.toggleMenu();
console.log("clicked");
e.stopPropagation();
}
toggleMenu() {
this.setState({
visible: !this.state.visible,
});
}
render() {
console.log("Rendering : MenuContainer");
return (
<div>
<MenuButton handleMouseDown={this.handleMouseDown} />
<Menu
handleMouseDown={this.handleMouseDown}
menuVisibility={this.state.visible}
/>
<div>
<p>Can you spot the item that doesn't belong?</p>
<ul>
<li>Lorem</li>
<li>Ipsum</li>
<li>Dolor</li>
<li>Sit</li>
<li>Bumblebees</li>
<li>Aenean</li>
<li>Consectetur</li>
</ul>
</div>
</div>
);
}
}
export default MenuContainer;
data:image/s3,"s3://crabby-images/dade9/dade9a32a895b6e60f3d306a14ab1f6e04671849" alt=""
-2. MenuButton.js
import React, { Component } from "react";
import "./MenuButton.css";
class MenuButton extends Component {
render() {
console.log("Rendering : MenuButton");
return (
<button
id="roundButton"
onMouseDown={this.props.handleMouseDown}
></button>
);
}
}
export default MenuButton;
data:image/s3,"s3://crabby-images/f8a35/f8a350d3ae2af6db6896731286e8631e10e9aa51" alt=""
-3. Menu.js
import React, { Component } from "react";
import "./Menu.css";
class Menu extends Component {
render() {
console.log("Rendering : Menu");
var visibility = "hide";
if (this.props.menuVisibility) {
visibility = "show";
}
return (
<div
id="flyoutMenu"
onMouseDown={this.props.handleMouseDown}
className={visibility}
>
<h2>
<a href="/">Home</a>
</h2>
<h2>
<a href="/">About</a>
</h2>
<h2>
<a href="/">Contact</a>
</h2>
<h2>
<a href="/">Search</a>
</h2>
</div>
);
}
}
export default Menu;
data:image/s3,"s3://crabby-images/cc5f4/cc5f451967d04555814c53406543267c35c20a0c" alt=""
-4.render呼び出しcheck
data:image/s3,"s3://crabby-images/9537e/9537e37549dd7824d9787420baa44210d90468b8" alt=""
data:image/s3,"s3://crabby-images/1f4a0/1f4a0eadf000b80c49159b232dc71fe1735ee063" alt=""
data:image/s3,"s3://crabby-images/c8863/c886300dab4a0b34d1237d37fee3502ec9c59438" alt=""
04.renderメソッドの呼び出しを避ける
-1.shouldComponentUpdateの再定義
_1. shouldComponentUpdate false return
import React, { Component } from "react";
import "./MenuButton.css";
class MenuButton extends Component {
shouldComponentUpdate(nextProps, nextState) {
return false;
}
render() {
console.log("Rendering : MenuButton");
return (
<button
id="roundButton"
onMouseDown={this.props.handleMouseDown}
></button>
);
}
}
export default MenuButton;
data:image/s3,"s3://crabby-images/cab55/cab557fdb12c6f4f94649d592bbd36fb91ebc1b3" alt=""
data:image/s3,"s3://crabby-images/24abf/24abf27969d43b1c52b07a2b31ae40d65840e1a3" alt=""
data:image/s3,"s3://crabby-images/550cf/550cff9e1dda304ecff063294fca0db858e43442" alt=""
_2. shouldComponentUpdate used parameters
import React, { Component } from "react";
import "./MenuButton.css";
class MenuButton extends Component {
shouldComponentUpdate(nextProps, nextState) {
if (this.props.handleMouseDown === nextProps.handleMouseDown) {
return false;
} else {
return true;
}
}
render() {
console.log("Rendering : MenuButton");
return (
<button
id="roundButton"
onMouseDown={this.props.handleMouseDown}
></button>
);
}
}
export default MenuButton;
data:image/s3,"s3://crabby-images/ac55c/ac55cfa67220e1b88d8968f79cb8114f98b9479b" alt=""
data:image/s3,"s3://crabby-images/f2ce6/f2ce63aefa97ab86c4e964a67ae591c049fc5d80" alt=""
data:image/s3,"s3://crabby-images/20ad5/20ad56db7468fb2ba8b9fe4546b9ea3d822c0259" alt=""
-3.PureCompentの使用
各
親構成部品をレンダーするたびに、
import React, { PureComponent } from "react";
import "./MenuButton.css";
class MenuButton extends PureComponent {
// shouldComponentUpdate(nextProps, nextState) {
// if (this.props.handleMouseDown === nextProps.handleMouseDown) {
// return false;
// } else {
// return true;
// }
// }
render() {
console.log("Rendering : MenuButton");
return (
<button
id="roundButton"
onMouseDown={this.props.handleMouseDown}
></button>
);
}
}
export default MenuButton;
data:image/s3,"s3://crabby-images/77ab9/77ab92bf7eea4b7e085bbfbd082b34e9e04c8582" alt=""
data:image/s3,"s3://crabby-images/d9928/d99283ff602d089f5c12386d7d7bed1b3d5e77c2" alt=""
data:image/s3,"s3://crabby-images/3a193/3a193eecd25507d555153e2a65d4dbd2e9afc69a" alt=""
Reference
この問題について(Learning React(12.React不要なレンダリングを除去)), 我々は、より多くの情報をここで見つけました https://velog.io/@ansalstmd/Learning-React12.-React-불필요한-렌더링-방지テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol