- Hands-On Design Patterns with React Native
- Mateusz Grzesiukiewicz
- 319字
- 2021-08-13 15:12:58
Examples of useful HOCs
Do you need a quick logger that will show you how your app behaves? Or maybe you are preparing a live presentation and you want to show some dynamic information on a screen? Here we go:
// src/ Chapter_1/ Example_16_Useful_HOCs/ App.js
const logPropChanges = Component => props => {
console.log('[Actual props]:', props);
return <Component {...props} />;
};
// Use: makeExpandable(logPropChanges(mapPropNames(SomeSection)));
Okay, good. Now, let's suppose that you are waiting on some data to load. Here comes the spinner:
// src/ Chapter_1/ Example_16_Useful_HOCs/ App.js
import {ActivityIndicator} from 'react-native';
const withSpinner = Component => props => (
props.shouldSpin
? <View style={styles.container}>
<Text>Your fav spinner f.in. on data load.</Text>
<ActivityIndicator size="large" color="#0000ff" />
</View>
: <Component {...props} />
);
// Needs a HOC that provides prop shouldSpin (true/false)
You might want to ask a user to five star your app. You need a modal to do this:
const withModalOpener = Component => props => (
// Replace with your favourite Modal box implementation
<Component {...props} openModal={() => console.log('opening...')} />
);
Sometimes, modals should be intelligent enough to maintain their visibility, too:
// src/ Chapter_1/ Example_16_Useful_HOCs/ App.js
const withModalOpener = OriginalComponent => (
class ModalExample extends React.Component {
// Check this shorter way to init state
state = {
modalVisible: true,
};
setModalVisible(visible) {
this.setState({modalVisible: visible});
}
render() {
return (
// Replace with your favourite Modal box implementation
<View style={styles.container}>
<OriginalComponent
{...this.props}
openModal={() => this.setModalVisible(true)}
closeModal={() =>
this.setModalVisible(false)}
/>
<Modal
animationType="slide"
visible={this.state.modalVisible}
onRequestClose={() => {
alert('Modal has been closed.');
}}>
<View style={styles.container}>
<Text>Example modal!</Text>
<TouchableHighlight
onPress={() => {
this.setModalVisible(false);
}}>
<Text style={{fontSize: 30}}>
Hide Modal
</Text>
</TouchableHighlight>
</View>
</Modal>
</View>
);
}
}
);
In this example, we enriched the component with Modal. Modal can be opened or closed using the props that are named openModal and closeModal. The information regarding whether the modal is opened or closed is stored within a private state of the HOC and, in this example, is not exposed to the original component. Nice separation, right? This HOC is also reusable.
Time for your homework: how do we make Modal open along with the box show? You cannot change SomeComponent.
- DevOps:軟件架構師行動指南
- 演進式架構(原書第2版)
- OpenCV實例精解
- AWS Serverless架構:使用AWS從傳統(tǒng)部署方式向Serverless架構遷移
- Vue.js快跑:構建觸手可及的高性能Web應用
- Python Geospatial Development(Second Edition)
- PHP+MySQL+Dreamweaver動態(tài)網(wǎng)站開發(fā)實例教程
- FFmpeg入門詳解:音視頻原理及應用
- 你不知道的JavaScript(中卷)
- Python面向?qū)ο缶幊蹋簶嫿ㄓ螒蚝虶UI
- 軟件供應鏈安全:源代碼缺陷實例剖析
- 深度探索Go語言:對象模型與runtime的原理特性及應用
- 從程序員角度學習數(shù)據(jù)庫技術(藍橋杯軟件大賽培訓教材-Java方向)
- Android Sensor Programming By Example
- Clojure Data Structures and Algorithms Cookbook