小編給大家分享一下React中高階組件如何使用,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比豐順網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式豐順網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋豐順地區(qū)。費用合理售后完善,10余年實體公司更值得信賴。
Higher-Order Components
HOC 不是React的標(biāo)準(zhǔn)API。
HOC 是一個函數(shù)。
HOC 返回一個Component。
示例:
const EnhancedComponent = higherOrderComponent(WrappedComponent);
類似React 0.15版本之前的mixin。
多個組件同用一段代碼,或者同樣的方法時,可以使用HOC。
示例:
import React, { PureComponent } from 'react';
const Common = (WrapComponent) => {
return (
<div>
<h2>Title</h2>
<WrapComponent />
</div>
);
};
const Header = () => <div>Header</div>;
const Footer = () => <div>Footer</div>;
export default class extends PureComponent {
render() {
return (
<div>
<div>
<p>Header Component</p>
{Common(Header)}
</div>
<hr />
<div>
<p>Footer Component</p>
{Common(Footer)}
</div>
</div>
);
}
}在線示例
抽象state和更改props
可以通過WrappedComponent包裹的組件公共state抽象出來。
可以通過WrappedComponent包裹的組件傳遞修改、添加等的props.
示例:
const HOComp = (WrappedComponent) => {
return class extends React.Component {
constructor(props) {
super(props);
this.state = {name: ''};
}
componentDidMount() {
this.setState({name: WrappedComponent.displayName || WrappedComponent.name || 'Component';});
}
return <WrappedComponent name={this.state.name} {...this.props}/>
}
}條件渲然。根據(jù)props或者state條件返回在渲然的內(nèi)容。
示例:
const HOComp = (WrappedComponent) => {
return class Enhancer extends WrappedComponent {
render() {
if (this.props.loggedIn) {
return super.render()
} else {
return null
}
}
}
}返回的高階組件類(Enhancer)繼承了 WrappedComponent。
示例:
const EnchanceComponent = (WrappedCompopnent) => {
return class extends WrappedCompopnent {
constructor(props) {
super(props);
this.state = { error: '' };
}
componentDidMount() {
/*do something*/
super.componentDidMount();
}
render() {
if (this.state.error) {
return <p>{this.state.error}</p>;
} else {
return super.render();
}
}
}
};看完了這篇文章,相信你對React中高階組件如何使用有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
名稱欄目:React中高階組件如何使用
分享鏈接:http://chinadenli.net/article34/pphpse.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、品牌網(wǎng)站建設(shè)、商城網(wǎng)站、做網(wǎng)站、網(wǎng)站內(nèi)鏈、品牌網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)