Przykład curry z ES6:
const clickHandler = param => event => {
console.log(param);
console.log(event.type);
};
Nasz przycisk, który przełącza obsługę:
<button onClick={(e) => clickHandler(1)(e)}>Click me!</button>
Jeśli chcesz wywołać to wyrażenie funkcyjne bez obiektu zdarzenia, nazwałbyś to w ten sposób:
clickHandler(1)();
Ponadto, ponieważ reakcja wykorzystuje zdarzenia syntetyczne (opakowanie dla zdarzeń natywnych), istnieje pula zdarzeń , co oznacza, że jeśli chcesz używać swojego event
obiektu asynchronicznie, musisz użyć event.persist()
:
const clickHandler = param => event => {
event.persist();
console.log(event.target);
setTimeout(() => console.log(event.target), 1000);
};
Oto przykład na żywo: https://codesandbox.io/s/compassionate-joliot-4eblc?fontsize=14&hidenavigation=1&theme=dark
onClick={(e) => { this.clickMe(e, someparameter) }}