Penyerahan Anti-Goncang dan Anti-Pendua PHP: Perkara yang mesti dimiliki untuk mengoptimumkan pengalaman interaksi pengguna
Apabila membangunkan aplikasi web, mengoptimumkan pengalaman interaksi pengguna adalah aspek yang sangat penting. Antaranya, penyerahan anti-goncang dan anti-pendua adalah dua teknologi yang sangat kritikal yang boleh mengurangkan operasi yang tidak perlu dengan berkesan dan meningkatkan kepuasan pengguna. Artikel ini akan memperkenalkan cara melaksanakan anti-goncang dan anti-penyerahan semula dalam PHP, dan menyediakan contoh kod khusus.
1. Konsep dan prinsip anti goncang
Anti goncang bermaksud apabila pengguna mencetuskan peristiwa secara berterusan, hanya operasi terakhir dilakukan, dengan itu mengelakkan pembaziran sumber yang tidak perlu yang disebabkan oleh kejadian yang sering dicetuskan. Dalam aplikasi web, peristiwa pencetus biasa termasuk klik butang, input kotak input, dsb.
Prinsip untuk mencapai anti-goncang adalah sangat mudah: dengan menetapkan pemasa, menangguhkan pelaksanaan operasi. Jika peristiwa yang sama dicetuskan lagi sebelum pemasa mula mengira, pemasa sebelumnya akan dibatalkan dan masa akan bermula semula. Dengan cara ini, tindakan itu hanya akan dilakukan selepas pengguna berhenti mencetuskan acara untuk seketika.
Berikut ialah contoh kod yang menggunakan PHP untuk melaksanakan anti goncang:
function debounce($callback, $delay) { $timeout = null; return function() use ($callback, $delay, &$timeout) { if ($timeout) { clearTimeout($timeout); } $timeout = setTimeout($callback, $delay); }; } // 使用示例 $debouncedFn = debounce(function() { // 这里是需要防抖的操作 }, 500); // 调用防抖函数 $debouncedFn();
Dalam kod di atas, fungsi debounce
menerima dua parameter: $callback
ialah operasi yang perlu dilakukan , $delay
ialah masa untuk menangguhkan pelaksanaan. Fungsi ini menggunakan penutupan secara dalaman dan mengekalkan pembolehubah $timeout
untuk menyimpan rujukan kepada pemasa. Apabila pengguna mencetuskan acara, pemasa sebelumnya dikosongkan dan pemasa baharu ditetapkan semula. debounce
函数接受两个参数:$callback
是需要执行的操作,$delay
是延迟执行的时间。函数内部使用闭包,维护了一个 $timeout
变量来保存定时器的引用。当用户触发事件时,会清除之前的定时器并重新设置一个新的定时器。
二、防重复提交的概念和原理
防重复提交是指在用户重复提交相同请求时,只处理一次请求,避免重复操作对数据造成的影响。在 Web 应用中,常见的重复提交场景包括表单提交、接口请求等。
实现防重复提交的原理也很简单:在用户提交请求时,将请求的标识存储在服务器端,如果下次再次收到相同的请求,则判断该请求已经处理过,直接返回结果。可以使用 Session 或者数据库等存储方式来实现。
以下是一个使用 PHP 实现防重复提交的示例代码:
function preventDuplicate($key) { session_start(); if ($_SESSION[$key]) { die('不能重复提交!'); } else { $_SESSION[$key] = true; } } // 使用示例 preventDuplicate('submit_key'); // 处理表单提交逻辑 // ...
在上述代码中,preventDuplicate
函数接受一个参数 $key
preventDuplicate
menerima parameter $key
, yang digunakan untuk mengenal pasti sama ada permintaan Sudah diproses. Fungsi ini menggunakan Sesi secara dalaman untuk menyimpan ID permintaan Jika ID sudah wujud, ini bermakna permintaan telah diproses dan mesej gesaan "tidak boleh dihantar semula" akan dikembalikan secara langsung. Atas ialah kandungan terperinci Penyerahan anti-goncang dan anti-pendua PHP: yang mesti ada untuk mengoptimumkan pengalaman interaksi pengguna. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!