PHP anti-goncang dan penyerahan anti-pendua: meningkatkan kecekapan operasi pengguna

WBOY
Lepaskan: 2023-10-12 13:12:01
asal
1374 orang telah melayarinya

PHP 防抖和防重复提交:提升用户操作的效率

Penyerahan Anti-Goncang dan Anti-Pendua PHP: Untuk meningkatkan kecekapan operasi pengguna, contoh kod khusus diperlukan

Dengan populariti Internet dan perkembangan teknologi, semakin ramai orang mula menggunakan pelbagai laman web dan aplikasi untuk pelbagai tujuan Operasi, seperti menghantar borang, menghantar permintaan, dsb. Walau bagaimanapun, dalam proses ini, kami sering menghadapi beberapa masalah, seperti pengguna kerap mengklik butang yang membawa kepada penyerahan borang berulang, atau permintaan kerap dihantar semasa interaksi bahagian hadapan yang membawa kepada peningkatan tekanan pelayan. Untuk meningkatkan kecekapan operasi pengguna, kami perlu menggunakan beberapa cara teknikal untuk menyelesaikan masalah ini, antaranya anti-goncang dan anti-pengulangan adalah penyelesaian biasa.

1. Anti goncang

Anti goncang ialah teknologi yang mengurangkan bilangan pencetus dengan menangguhkan pelaksanaan atau menggabungkan operasi berturut-turut apabila pengguna kerap beroperasi. Sebagai contoh, kami mempunyai kotak carian pada halaman web Apabila pengguna memasukkan dengan cepat dan berterusan, kami berharap dapat mencari selepas pengguna berhenti menaip untuk satu tempoh masa, dan bukannya mencetuskan permintaan carian setiap kali dia memasukkan. Ini boleh mengurangkan bilangan permintaan yang tidak perlu dan meningkatkan pengalaman pengguna.

Dalam PHP, kita boleh mencapai kesan anti goncang dengan menggunakan pemasa. Berikut ialah contoh kod:

function debounceSearch($keywords) {
    // 保存上一次触发搜索的定时器 ID
    static $timer = null;

    // 清除上一次的延时操作
    if ($timer) {
        clearTimeout($timer);
    }

    // 创建新的延时操作
    $timer = setTimeout(function() use ($keywords) {
        // 这里是实际的搜索逻辑
        searchKeywords($keywords);
    }, 500); // 延时 500ms
}

// 在表单或输入框的事件监听中调用 debounceSearch 函数即可实现防抖
Salin selepas log masuk

Dalam kod di atas, kami menggunakan pembolehubah statik $timer untuk menyimpan ID pemasa terakhir yang mencetuskan carian. Apabila pengguna memasukkan, mula-mula tentukan sama ada terdapat operasi tertunda sebelumnya. Jika ya, kosongkan operasi tertunda terakhir dahulu, dan kemudian buat operasi tertunda yang baharu. Ini memastikan bahawa pengguna berhenti menaip untuk tempoh masa sebelum mencari. $timer 来保存上一次触发搜索的定时器 ID。当用户输入时,首先判断是否有上一次的延时操作,如果有,则先清除上一次的延时操作,然后再创建新的延时操作。这样就能保证用户停止输入一段时间后才进行搜索。

二、防重复提交

防重复提交是一种在用户提交表单或发送请求时,通过一些方法来避免重复提交的技术。比如用户在网页上点击提交按钮后,如果网络较慢或者用户不小心多次点击按钮,就可能导致同一个表单被提交多次。为了避免这种情况的发生,我们可以在后台进行一些处理来阻止重复提交。

在 PHP 中,我们可以通过使用 token 来防止重复提交。下面是一个示例代码:

function verifyToken($token) {
    // 检查 token 是否有效,可以从 Session 或者数据库中获取相应的 token 进行比对
    if ($token == $_SESSION['token']) {
        // token 有效
        return true;
    } else {
        // token 无效
        return false;
    }
}

function processForm($data, $token) {
    // 首先检查 token 是否有效
    if (!verifyToken($token)) {
        // token 无效,则认为是重复提交,直接返回
        return;
    }

    // 这里是实际的表单处理逻辑
    doSomething($data);

    // 处理完成后,清除 token,避免同一个表单被重复提交
    unset($_SESSION['token']);
}

// 在表单提交前生成 token,并保存到 Session 或者数据库中
// 将 token 输出到表单中的隐藏字段或者 URL 参数中
Salin selepas log masuk

上面的代码中,我们首先定义了一个 verifyToken 函数,用来检查给定的 token 是否有效。然后在 processForm 函数中,先调用 verifyToken

2. Penyerahan anti-pendua

Penyerahan anti-pendua ialah teknologi yang menggunakan beberapa kaedah untuk mengelakkan penyerahan berulang apabila pengguna menghantar borang atau menghantar permintaan. Sebagai contoh, selepas pengguna mengklik butang hantar pada halaman web, jika rangkaian perlahan atau pengguna mengklik butang itu secara tidak sengaja beberapa kali, borang yang sama boleh diserahkan beberapa kali. Untuk mengelakkan perkara ini berlaku, kami boleh melakukan beberapa pemprosesan di latar belakang untuk mengelakkan penyerahan berulang.

Dalam PHP, kami boleh menghalang penyerahan pendua dengan menggunakan token. Berikut ialah contoh kod:

rrreee

Dalam kod di atas, kami mula-mula mentakrifkan fungsi verifyToken untuk menyemak sama ada token yang diberikan adalah sah. Kemudian dalam fungsi processForm, mula-mula panggil fungsi verifyToken untuk menyemak sama ada token itu sah Jika ia tidak sah, ia dianggap sebagai penyerahan berulang dan dikembalikan terus; jika sah, logik pemprosesan borang sebenar dilakukan , dan kosongkan token selepas pemprosesan selesai untuk mengelakkan borang yang sama daripada dihantar berulang kali. 🎜🎜Dengan cara ini, apabila pengguna menyerahkan borang, kami hanya perlu mengesahkan kesahihan token di latar belakang, yang boleh menghalang penyerahan berulang dengan berkesan. 🎜🎜Ringkasan🎜🎜Melalui cara teknikal anti-goncang dan anti-pendua, kami boleh meningkatkan kecekapan operasi pengguna, mengurangkan permintaan dan tekanan pelayan yang tidak perlu, dan meningkatkan pengalaman pengguna. Dalam PHP, kita boleh menggunakan pemasa untuk mencapai anti-goncang dan token untuk mengelakkan penyerahan berulang. Di atas hanyalah satu daripada dua penyelesaian Bergantung kepada keperluan dan keadaan sebenar, kita boleh memilih kaedah yang sesuai untuk menyelesaikan masalah. 🎜

Atas ialah kandungan terperinci PHP anti-goncang dan penyerahan anti-pendua: meningkatkan kecekapan operasi pengguna. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!