Przykład ze strategią
Podobają mi się dostarczone rozwiązania, które wykorzystują to samo, tworząc opakowanie wokół komponentu.
Ponieważ jest to bardziej zachowanie, pomyślałem o strategii i wymyśliłem następujące.
Jestem nowy z React i potrzebuję trochę pomocy, aby zaoszczędzić trochę płyty grzewczej w przypadkach użycia
Przejrzyj i powiedz mi, co myślisz.
ClickOutsideBehavior
import ReactDOM from 'react-dom';
export default class ClickOutsideBehavior {
constructor({component, appContainer, onClickOutside}) {
// Can I extend the passed component's lifecycle events from here?
this.component = component;
this.appContainer = appContainer;
this.onClickOutside = onClickOutside;
}
enable() {
this.appContainer.addEventListener('click', this.handleDocumentClick);
}
disable() {
this.appContainer.removeEventListener('click', this.handleDocumentClick);
}
handleDocumentClick = (event) => {
const area = ReactDOM.findDOMNode(this.component);
if (!area.contains(event.target)) {
this.onClickOutside(event)
}
}
}
Przykładowe użycie
import React, {Component} from 'react';
import {APP_CONTAINER} from '../const';
import ClickOutsideBehavior from '../ClickOutsideBehavior';
export default class AddCardControl extends Component {
constructor() {
super();
this.state = {
toggledOn: false,
text: ''
};
this.clickOutsideStrategy = new ClickOutsideBehavior({
component: this,
appContainer: APP_CONTAINER,
onClickOutside: () => this.toggleState(false)
});
}
componentDidMount () {
this.setState({toggledOn: !!this.props.toggledOn});
this.clickOutsideStrategy.enable();
}
componentWillUnmount () {
this.clickOutsideStrategy.disable();
}
toggleState(isOn) {
this.setState({toggledOn: isOn});
}
render() {...}
}
Notatki
Pomyślałem o przechowywaniu component
przechwyconych haków cyklu życia i zastąpiłem je metodami podobnymi do tego:
const baseDidMount = component.componentDidMount;
component.componentDidMount = () => {
this.enable();
baseDidMount.call(component)
}
component
jest komponentem przekazanym do konstruktora ClickOutsideBehavior
.
Spowoduje to usunięcie włączania / wyłączania elementu kotłowego od użytkownika tego zachowania, ale nie wygląda to zbyt ładnie