Debouncing
El debouncing es una técnica que retrasa la ejecución de una acción hasta que ha transcurrido un tiempo específico desde la última llamada. Cada nueva llamada reinicia el temporizador. Esto es útil para escenarios como la búsqueda a medida que se escribe, donde quieres esperar hasta que el usuario deja de escribir antes de ejecutar una consulta de búsqueda.
Mostrar Código
- Java
Uso básico
La clase Debouncer proporciona una manera sencilla de deboncear acciones. Crea un Debouncer con un retraso en segundos, luego llama a run() con la acción que deseas deboncear:
Debouncer debounce = new Debouncer(0.3f);
textField.onModify(e -> {
debounce.run(() -> search(textField.getText()));
});
En este ejemplo, el método search() se llama solo después de que el usuario deja de escribir durante 300 milisegundos. Cada pulsación de tecla reinicia el temporizador a través del evento onModify, así que escribir rápidamente no activará múltiples búsquedas.
Cómo funciona
Cuando llamas a run() con una acción:
- Si no hay ninguna acción pendiente, el
Debouncerprograma la acción para ejecutarse después del retraso. - Si ya hay una acción pendiente, la acción anterior se cancela y el temporizador se reinicia con la nueva acción.
- Una vez que transcurre el retraso sin otra llamada, la acción se ejecuta.
El Debouncer se ejecuta en el hilo de UI utilizando el mecanismo de Interval de webforJ, así que no necesitas envolver actualizaciones de la UI en Environment.runLater().
El parámetro de retraso utiliza segundos como unidad, no milisegundos. Usa 0.3f para 300 ms o 1.5f para 1.5 segundos.
Controlando la ejecución
Los siguientes métodos se pueden utilizar para manejar de manera más precisa la ejecución y el uso del Debouncer:
Cancelando una acción pendiente
Usa cancel() para detener una acción pendiente de ejecutarse:
Debouncer debounce = new Debouncer(1f);
debounce.run(() -> saveDocument());
// El usuario navega lejos antes de que se ejecute el guardado
debounce.cancel();
Al igual que con los intervalos, es buena práctica cancelar las acciones debonceadas pendientes cuando un componente es destruido. Esto previene fugas de memoria y evita errores de acciones que se ejecutan en componentes destruidos:
public class SearchPanel extends Composite<Div> {
private final Debouncer debounce = new Debouncer(0.3f);
@Override
protected void onDidDestroy() {
debounce.cancel();
}
}
Forzando la ejecución inmediata
Usa flush() para ejecutar una acción pendiente inmediatamente:
Debouncer debounce = new Debouncer(0.5f);
textField.onModify(e -> {
debounce.run(() -> validateInput(textField.getText()));
});
// Forzar validación antes de enviar el formulario
submitButton.onClick(e -> {
debounce.flush();
if (isValid()) {
submitForm();
}
});
Comprobando el estado pendiente
Usa isPending() para verificar si una acción está esperando para ejecutarse:
Debouncer debounce = new Debouncer(0.3f);
if (debounce.isPending()) {
statusLabel.setText("Procesando...");
}
Debouncing a nivel de evento vs Debouncer
webforJ proporciona dos enfoques para el debouncing:
| Característica | Debouncer | ElementEventOptions.setDebounce() |
|---|---|---|
| Alcance | Cualquier acción | Solo eventos de elemento |
| Ubicación | Lado del servidor | Lado del cliente |
| Unidad | Segundos (float) | Milisegundos (int) |
| Flexibilidad | Control total con cancelación/vaciado | Automático con evento |
Usa Debouncer cuando necesites control programático sobre el debouncing, como cancelar o vaciar acciones pendientes. Usa ElementEventOptions cuando desees un debouncing simple del lado del cliente para eventos de elementos sin viajes adicionales al servidor.
// Usando ElementEventOptions para debouncing del lado del cliente
ElementEventOptions options = new ElementEventOptions();
options.setDebounce(300);
element.addEventListener("input", e -> {
// Este manejador está debonceado en el cliente
}, options);