Solution un mapPropsToHandler et event.target.
Les fonctions sont des objets en js, il est donc possible de leur attacher des propriétés.
function onChange() { console.log(onChange.list) }
function Input(props) {
onChange.list = props.list;
return <input onChange={onChange}/>
}
cette fonction ne lie qu'une seule fois une propriété à une fonction.
export function mapPropsToHandler(handler, props) {
for (let property in props) {
if (props.hasOwnProperty(property)) {
if(!handler.hasOwnProperty(property)) {
handler[property] = props[property];
}
}
}
}
Je reçois mes accessoires comme ça.
export function InputCell({query_name, search, loader}) {
mapPropsToHandler(onChange, {list, query_name, search, loader});
return (
<input onChange={onChange}/>
);
}
function onChange() {
let {query_name, search, loader} = onChange;
console.log(search)
}
Cet exemple combine à la fois event.target et mapPropsToHandler. Il est préférable d'attacher des fonctions aux gestionnaires uniquement, et non à des nombres ou à des chaînes de caractères. Les nombres et les chaînes de caractères peuvent être passés à l'aide d'un attribut DOM comme
<select data-id={id}/>
plutôt que mapPropsToHandler
import React, {PropTypes} from "react";
import swagger from "../../../swagger/index";
import {sync} from "../../../functions/sync";
import {getToken} from "../../../redux/helpers";
import {mapPropsToHandler} from "../../../functions/mapPropsToHandler";
function edit(event) {
let {translator} = edit;
const id = event.target.attributes.getNamedItem('data-id').value;
sync(function*() {
yield (new swagger.BillingApi())
.billingListStatusIdPut(id, getToken(), {
payloadData: {"admin_status": translator(event.target.value)}
});
});
}
export default function ChangeBillingStatus({translator, status, id}) {
mapPropsToHandler(edit, {translator});
return (
<select key={Math.random()} className="form-control input-sm" name="status" defaultValue={status}
onChange={edit} data-id={id}>
<option data-tokens="accepted" value="accepted">{translator('accepted')}</option>
<option data-tokens="pending" value="pending">{translator('pending')}</option>
<option data-tokens="rejected" value="rejected">{translator('rejected')}</option>
</select>
)
}
solution deux. délégation d'événements
voir la solution 1. nous pouvons enlever le gestionnaire d'événement de l'entrée et le mettre à son parent qui contient d'autres entrées aussi et par l'aide de la technique de délégation nous pouvons être utiliser event.traget et la fonction mapPropsToHandler à nouveau.
0 votes
UseCallback - const memoizedCallback = useCallback( () => { doSomething(a, b) ; }, [a, b], ) ; Retourne un callback mémorisé.