|
導讀網頁的本質就是超級文本標記語言,通過結合使用其他的Web技術(如:腳本語言、公共網關接口、組件等),可以創造出功能強大的網頁。因而,超級文本標記語言是萬維網(Web)編程的基礎,也就是說萬維網是建立... 網頁的本質就是超級文本標記語言,通過結合使用其他的Web技術(如:腳本語言、公共網關接口、組件等),可以創造出功能強大的網頁。因而,超級文本標記語言是萬維網(Web)編程的基礎,也就是說萬維網是建立在超文本基礎之上的。超級文本標記語言之所以稱為超文本標記語言,是因為文本中包含了所謂“超級鏈接”點。 本篇文章給大家帶來的內容是關于React中高階組件的使用示例,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。 Higher-Order Components
示例: const EnhancedComponent = higherOrderComponent(WrappedComponent); 使用場景代碼復用類似React 0.15版本之前的mixin。 多個組件同用一段代碼,或者同樣的方法時,可以使用HOC。 示例: import React, { PureComponent } from 'react';
const Common = (WrapComponent) => {
return (
<div>
<h1>Title</h1>
<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}/>
}
}渲然劫持條件渲然。根據props或者state條件返回在渲然的內容。 示例: 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中高階組件的使用示例的詳細內容,更多請關注php中文網其它相關文章! 網站建設是一個廣義的術語,涵蓋了許多不同的技能和學科中所使用的生產和維護的網站。 |
溫馨提示:喜歡本站的話,請收藏一下本站!