Rumah pembangunan bahagian belakang tutorial php Penyerahan anti-goncang dan anti-pendua PHP: yang mesti ada untuk mengoptimumkan pengalaman interaksi pengguna

Penyerahan anti-goncang dan anti-pendua PHP: yang mesti ada untuk mengoptimumkan pengalaman interaksi pengguna

Oct 12, 2023 pm 02:52 PM
php Anti goncang Cegah penyerahan pendua

PHP 防抖和防重复提交:优化用户交互体验的必备之道

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();
Salin selepas log masuk

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');

// 处理表单提交逻辑
// ...
Salin selepas log masuk

在上述代码中,preventDuplicate 函数接受一个参数 $key

2. Konsep dan prinsip penyerahan anti-pendua

Serahan anti-pendua bermakna apabila pengguna berulang kali menghantar permintaan yang sama, hanya satu permintaan akan diproses untuk mengelakkan kesan operasi berulang pada data. Dalam aplikasi web, senario penyerahan berulang yang biasa termasuk penyerahan borang, permintaan antara muka, dsb.
  1. Prinsip menghalang penyerahan berulang juga sangat mudah: apabila pengguna menyerahkan permintaan, pengenalan permintaan disimpan di bahagian pelayan Jika permintaan yang sama diterima lagi pada masa akan datang, ia akan dinilai bahawa permintaan itu telah diproses dan hasilnya akan dikembalikan terus. Ini boleh dicapai menggunakan kaedah penyimpanan seperti Sesi atau pangkalan data.
Berikut ialah contoh kod yang menggunakan PHP untuk menghalang penyerahan pendua:
    rrreee
  • Dalam kod di atas, fungsi 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.
  • 3. Senario aplikasi anti-goncang dan penyerahan anti-berulang
    Senario aplikasi anti-goncang:
    Cegah klik berulang pada butang dan elakkan permintaan pengguna yang kerap
  • ; permintaan tidak sah.
  • Senario permohonan untuk menghalang penyerahan berulang:

Penyerahan borang untuk mengelakkan pemasukan berulang ke dalam pangkalan data yang menyebabkan lebihan data

Halaman pembayaran untuk mengelakkan permintaan berulang untuk mengulangi operasi;

🎜Dengan menggunakan teknologi anti goncang dan anti penyerahan semula secara rasional, pengalaman interaksi pengguna dapat dioptimumkan dengan berkesan dan operasi yang tidak perlu serta pembaziran sumber dapat dikurangkan. Dalam pembangunan sebenar, mengikut keperluan dan senario tertentu, kaedah yang sesuai dipilih untuk pelaksanaan, dan penyesuaian dan pengoptimuman yang sesuai dijalankan mengikut keperluan perniagaan tertentu. 🎜🎜Ringkasan🎜🎜Artikel ini memperkenalkan konsep, prinsip dan kaedah pelaksanaan penyerahan anti-goncang dan anti-ulang dalam PHP, dan menyediakan contoh kod khusus. Dengan menggunakan anti-goncang dan anti-penyerahan semula, pengalaman interaktif pengguna boleh dipertingkatkan dan operasi yang tidak perlu serta pembaziran sumber dapat dikurangkan. Dalam pembangunan sebenar, kita harus memilih dan menggunakan teknologi ini secara rasional mengikut keperluan dan senario tertentu untuk mencapai hasil yang terbaik. 🎜

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!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

CakePHP Bekerja dengan Pangkalan Data CakePHP Bekerja dengan Pangkalan Data Sep 10, 2024 pm 05:25 PM

Bekerja dengan pangkalan data dalam CakePHP adalah sangat mudah. Kami akan memahami operasi CRUD (Buat, Baca, Kemas Kini, Padam) dalam bab ini.

Tarikh dan Masa CakePHP Tarikh dan Masa CakePHP Sep 10, 2024 pm 05:27 PM

Untuk bekerja dengan tarikh dan masa dalam cakephp4, kami akan menggunakan kelas FrozenTime yang tersedia.

Muat naik Fail CakePHP Muat naik Fail CakePHP Sep 10, 2024 pm 05:27 PM

Untuk mengusahakan muat naik fail, kami akan menggunakan pembantu borang. Di sini, adalah contoh untuk muat naik fail.

Bincangkan CakePHP Bincangkan CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP ialah rangka kerja sumber terbuka untuk PHP. Ia bertujuan untuk menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP adalah berdasarkan seni bina seperti MVC yang berkuasa dan mudah difahami. Model, Pandangan dan Pengawal gu

Pengesah Mencipta CakePHP Pengesah Mencipta CakePHP Sep 10, 2024 pm 05:26 PM

Pengesah boleh dibuat dengan menambah dua baris berikut dalam pengawal.

Pembalakan CakePHP Pembalakan CakePHP Sep 10, 2024 pm 05:26 PM

Log masuk CakePHP adalah tugas yang sangat mudah. Anda hanya perlu menggunakan satu fungsi. Anda boleh log ralat, pengecualian, aktiviti pengguna, tindakan yang diambil oleh pengguna, untuk sebarang proses latar belakang seperti cronjob. Mengelog data dalam CakePHP adalah mudah. Fungsi log() disediakan

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Dec 20, 2024 am 11:31 AM

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

See all articles