Rumah > pembangunan bahagian belakang > masalah PHP > Bagaimana untuk melaksanakan bar kemajuan dalam php

Bagaimana untuk melaksanakan bar kemajuan dalam php

PHPz
Lepaskan: 2023-04-19 10:36:09
asal
1743 orang telah melayarinya

Dengan pembangunan berterusan aplikasi Internet, pembangunan web telah menjadi bidang yang sangat penting. Sebagai bahasa skrip pelayan yang biasa digunakan, PHP digunakan secara meluas dalam pembangunan web. Antaranya, operasi seperti memproses sejumlah besar data, memuat naik fail dan memuat turun tidak dapat tidak memerlukan penggunaan bar kemajuan, supaya pengguna dapat merasakan kemajuan operasi dengan lebih intuitif. Artikel ini akan memperkenalkan beberapa kaedah dan teknik untuk melaksanakan bar kemajuan dalam PHP untuk membantu pembaca menggunakan fungsi ini dengan lebih baik.

1. Pelaksanaan AJAX bar kemajuan

Ajax ialah teknologi yang menggunakan teknologi JavaScript dan XML untuk komunikasi tak segerak tanpa menyegarkan keseluruhan halaman bar adalah Salah satu aplikasi. Langkah pelaksanaan khusus adalah seperti berikut:

  1. Tambah kod html bar kemajuan dalam halaman HTML, seperti yang ditunjukkan di bawah:
<div id="progressBar">
   <div id="progress"></div>
</div>
Salin selepas log masuk
Salin selepas log masuk
  1. Tentukan permintaan AJAX dalam Javascript , menghantar maklumat kemajuan ke kod back-end melalui komunikasi tak segerak. Berikut ialah contoh mudah:
function uploadFile() {
    var xhr = new XMLHttpRequest();
    xhr.upload.addEventListener('progress', function(e) {
        var percent = e.loaded / e.total * 100;
        document.getElementById('progress').style.width = percent + '%';
    }, false);
    xhr.open('POST', 'upload.php');
    xhr.send(formData);
}
Salin selepas log masuk
  1. Selepas kod bahagian belakang menerima maklumat kemajuan, ia melaksanakan pemprosesan dan operasi yang sepadan, dan mengembalikan hasil pemprosesan ke bahagian hadapan. . Kodnya adalah seperti berikut:
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');
header('Connection: keep-alive');

echo "data: {$percent}%\n\n";
flush();
Salin selepas log masuk

Dengan kaedah ini, kemajuan bar kemajuan boleh dipaparkan pada halaman dalam masa nyata apabila memuat naik atau memuat turun fail yang lebih besar, membolehkan pengguna memahami status operasi dengan lebih jelas.

2. Gunakan Sesi untuk melaksanakan bar kemajuan

Sesi ialah mekanisme untuk menyimpan maklumat sesi pengguna. Kami boleh menggunakan Sesi untuk menyimpan maklumat kemajuan dan menyampaikannya ke halaman hujung hadapan dalam masa nyata untuk mengemas kini status bar kemajuan. Langkah pelaksanaan khusus adalah seperti berikut:

  1. Tambah kod html bar kemajuan dalam halaman HTML, seperti yang ditunjukkan di bawah:
<div id="progressBar">
   <div id="progress"></div>
</div>
Salin selepas log masuk
Salin selepas log masuk
  1. Lakukan ia dalam kod bahagian belakang Proses dan simpan maklumat kemajuan dalam Sesi. Berikut ialah contoh mudah:
session_start();
for ($i=0; $i<=100; $i++) {
    $_SESSION[&#39;progress&#39;] = $i;
    // 文件处理或上传下载等操作
}
Salin selepas log masuk
  1. Dalam halaman HTML, gunakan Javascript untuk kerap mendapatkan maklumat kemajuan daripada pelayan dan mengemas kini status bar kemajuan. Kodnya adalah seperti berikut:
setInterval(function() {
   var xhr = new XMLHttpRequest();
   xhr.open(&#39;GET&#39;, &#39;progress.php&#39;);
   xhr.onload = function() {
      var percent = parseInt(xhr.responseText);
      document.getElementById(&#39;progress&#39;).style.width = percent + &#39;%&#39;;
   };
   xhr.send(null);
}, 1000);
Salin selepas log masuk
  1. Di bahagian pelayan, balas permintaan bar kemajuan bahagian hadapan dan kembalikan maklumat kemajuan semasa. Berikut ialah contoh mudah:
session_start();
if (isset($_SESSION[&#39;progress&#39;])) {
    echo $_SESSION[&#39;progress&#39;];
} else {
    echo "0";
}
Salin selepas log masuk

Kaedah pelaksanaan ini sangat mudah dan boleh mencapai kesan bar kemajuan dengan baik apabila jumlah data adalah kecil. Walau bagaimanapun, terdapat juga beberapa kekurangan Sebagai contoh, dalam situasi konkurensi yang tinggi, ia boleh menyebabkan terlalu banyak permintaan dan menjejaskan prestasi pelayan Dalam kes ini, kaedah lain boleh dipertimbangkan untuk melaksanakan bar kemajuan.

3. Pustaka pihak ketiga untuk melaksanakan bar kemajuan

Selain itu, terdapat banyak perpustakaan pihak ketiga yang boleh digunakan untuk melaksanakan fungsi bar kemajuan. Sesetengah perpustakaan ini adalah percuma dan sumber terbuka, seperti Bootstrap, jQuery, NProgress, dll. Menggunakannya boleh memudahkan kesukaran menulis kod dan meningkatkan kecekapan pembangunan.

Sebagai contoh, untuk menggunakan perpustakaan Bootstrap untuk melaksanakan bar kemajuan, anda hanya perlu memperkenalkan fail CSS dan JS yang berkaitan ke dalam halaman HTML dan mentakrifkan kod html bar kemajuan:

<div class="progress">
   <div class="progress-bar" role="progressbar" aria-valuenow="60" aria-valuemin="0" aria-valuemax="100" style="width: 60%;">
      <span class="sr-only">60%Complete</span>
   </div>
</div>
Salin selepas log masuk

Dengan cara ini Anda boleh melaksanakan bar kemajuan dengan kesan dinamik dan anda boleh mengawal kemajuan bar kemajuan pada bila-bila masa dengan menukar nilai atribut gaya.

Ringkasan

Bar kemajuan ialah fungsi Web yang biasa digunakan, yang memainkan peranan penting dalam memproses sejumlah besar data, memuat naik dan memuat turun fail serta operasi lain. Artikel ini memperkenalkan tiga kaedah untuk melaksanakan bar kemajuan dalam PHP: Ajax, Session dan perpustakaan pihak ketiga. Setiap kaedah mempunyai kelebihan dan kekurangannya, dan anda boleh memilih kaedah yang sesuai dengan anda untuk melaksanakan bar kemajuan. Saya harap artikel ini dapat membantu pembaca menggunakan teknologi PHP dengan lebih baik untuk melaksanakan fungsi bar kemajuan.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan bar kemajuan dalam php. 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