import React from "react";
function memo() {
let template,cache_data;
return function (props) {
if(cache_data===props.data){
return template;
}else{
cache_data=props.data;
return template=<React.Fragment>
{
function () {
console.log("第一次加载时触发,更新不会触发");
return props.data.toString();
}()
}
</React.Fragment>
}
}
}
export const Child=memo();
这个子组件在第一次加载时会触发,如果父组件传入的data不变,则不会触发更新。 这里我用的是react hooks,所以没有shouldComponentUpdate方法,但是react依然能跳过更新,我想知道这是怎么跳过更新的?