Jadual Kandungan
Kaedah 1: Gunakan JSON
Kaedah 2: Gunakan serialize() dan unserialize()
Kaedah 3: Gunakan atribut HTML5 data-*
Kaedah 4: Gunakan AjaxTransport
Rumah pembangunan bahagian belakang masalah PHP Bagaimana untuk menghantar array php ke js

Bagaimana untuk menghantar array php ke js

May 19, 2023 pm 05:45 PM

Memandangkan trend pemisahan bahagian hadapan dan bahagian belakang terus bertambah kukuh, terdapat lebih banyak kes di mana bahagian hadapan perlu berinteraksi dengan data bahagian belakang. Dalam kes ini, bahagian hadapan perlu boleh mendapatkan data yang diproses oleh bahagian belakang, yang biasanya mengembalikan data dalam bentuk tatasusunan. Oleh itu, cara untuk menghantar tatasusunan PHP ke JS telah menjadi isu yang sangat penting.

Artikel ini akan memperkenalkan beberapa kaedah biasa untuk menghantar tatasusunan PHP, supaya pembaca boleh mendapatkan dan memproses data yang dikembalikan oleh bahagian belakang dengan lebih mudah apabila berinteraksi dengan data bahagian hadapan dan belakang. Kaedah khusus adalah seperti berikut:

Kaedah 1: Gunakan JSON

Pada masa ini, penyelesaian yang paling biasa untuk interaksi data bahagian hadapan dan bahagian belakang ialah menggunakan JSON. JSON (JavaScript Object Notation) ialah format pertukaran data ringan yang mudah dibaca dan ditulis, serta mudah dihuraikan dan dijana oleh mesin, menjadikannya sangat sesuai untuk pertukaran data. PHP mempunyai fungsi terbina dalam json_encode() yang boleh menukar tatasusunan PHP ke dalam format JSON, kemudian memindahkannya ke bahagian hadapan menggunakan teknologi AJAX, dan kemudian menggunakan JSON.parse() untuk menukarnya menjadi objek yang JavaScript boleh memanipulasi secara langsung .

Gunakan kod PHP untuk menukar tatasusunan kepada JSON:

$myArray = array("name" => "Tom", "age" => "18", "gender" => "male");
$json = json_encode($myArray);
Salin selepas log masuk
Salin selepas log masuk

Gunakan AJAX di bahagian hadapan untuk mendapatkan data JSON:

var request = new XMLHttpRequest();
request.open('GET', 'my_array.php', true);

request.onload = function() {
  if (request.status >= 200 && request.status < 400) {
    var data = JSON.parse(request.responseText);
    console.log(data);
  } else {
    console.log("Error!");
  }
};

request.send();
Salin selepas log masuk

Dalam kod di atas, kami menggunakan XMLHttpRequest objek untuk meminta data daripada pelayan , dan gunakan kaedah JSON.parse() untuk menukar rentetan format JSON yang diperolehi kepada objek JavaScript.

Kaedah 2: Gunakan serialize() dan unserialize()

Jika kita tidak perlu mempertimbangkan struktur data semasa menghantar data, maka fungsi serialize() dan unserialize() akan menjadi satu Bukan pilihan yang buruk.

Fungsi serialize() menyerikan pembolehubah menjadi rentetan, dan fungsi unserialize() boleh memulihkan rentetan kepada jenis data asal. Dalam PHP, kita boleh menggunakan serialize() untuk mensirikan tatasusunan ke dalam rentetan, kemudian gunakan AJAX untuk mendapatkan data dan kemudian menyahsirikannya.

Gunakan kod PHP untuk menyerikan tatasusunan:

$myArray = array("name" => "Tom", "age" => "18", "gender" => "male");
$serializedData = serialize($myArray);
Salin selepas log masuk

Gunakan AJAX di bahagian hadapan untuk mendapatkan rentetan bersiri:

var request = new XMLHttpRequest();
request.open('GET', 'my_array.php', true);

request.onload = function() {
  if (request.status >= 200 && request.status < 400) {
    var data = request.responseText;
    console.log(data);
  } else {
    console.log("Error!");
  }
};

request.send();
Salin selepas log masuk

Seterusnya, kita boleh menggunakan kaedah unserialize() kepada Ia dinyahsiri menjadi objek PHP:

$unserializedData = unserialize($serializedData);
print_r($unserializedData);
Salin selepas log masuk

Kaedah 3: Gunakan atribut HTML5 data-*

Jika kita hanya perlu menghantar beberapa data mudah dan tidak perlu menggunakan permintaan AJAX, maka kita boleh tatasusunan PHP dihantar ke hujung hadapan melalui atribut data HTML5-. Atribut data- ialah atribut tersuai yang boleh digunakan untuk menyimpan data tersuai elemen halaman untuk melaksanakan pengikatan data pada bahagian hadapan. Mula-mula kita boleh mentakrifkan atribut data-* pada elemen HTML, kemudian menukar data kepada rentetan format JSON dalam PHP, dan akhirnya menggunakan PHP untuk mengeluarkannya ke halaman.

Gunakan kod PHP untuk menukar tatasusunan kepada JSON dan mengeluarkannya kepada atribut data-*:

$myArray = array("name" => "Tom", "age" => "18", "gender" => "male");
$json = json_encode($myArray);

echo '
This is my div
';
Salin selepas log masuk

Seterusnya, kita boleh mendapatkan elemen ini melalui JavaScript dan menghuraikan atribut data-json menjadi Objek JavaScript :

var myDiv = document.getElementById("myDiv");
var jsonData = JSON.parse(myDiv.dataset.json);
console.log(jsonData);
Salin selepas log masuk

Kaedah 4: Gunakan AjaxTransport

Kadangkala, apabila kita berinteraksi dengan data bahagian hadapan dan bahagian belakang, kita perlu menyesuaikan beberapa parameter untuk memudahkan pemprosesan bahagian belakang. Dalam kes ini, anda boleh menggunakan AjaxTransport dalam jQuery. AjaxTransport membolehkan kami melakukan beberapa operasi tersuai sebelum menghantar permintaan AJAX, seperti menambah parameter tersuai dalam pengepala permintaan untuk memudahkan pemprosesan bahagian belakang tatasusunan PHP.

Gunakan kod PHP untuk menukar tatasusunan kepada JSON:

$myArray = array("name" => "Tom", "age" => "18", "gender" => "male");
$json = json_encode($myArray);
Salin selepas log masuk
Salin selepas log masuk

Apabila pengguna menghantar permintaan AJAX, kami boleh menambah data JSON ini pada pengepala permintaan:

$.ajaxTransport("+json", function(options, originalOptions, xhr) {
  xhr.setRequestHeader("X-JSON", json);
});
Salin selepas log masuk

Dalam bahagian belakang Dalam PHP, kita boleh mendapatkan tatasusunan PHP berdasarkan parameter tersuai yang ditambahkan dalam pengepala permintaan:

rreee

Ringkasnya, kita boleh menggunakan pelbagai kaedah untuk memindahkan tatasusunan PHP ke JavaScript, yang sepatutnya berdasarkan situasi tertentu Pilih pilihan yang paling sesuai. Secara keseluruhannya, menguasai kaedah ini membolehkan pembangun berinteraksi dengan data bahagian hadapan dan belakang dengan lebih fleksibel dan meningkatkan kecekapan pembangunan.

Atas ialah kandungan terperinci Bagaimana untuk menghantar array php ke js. 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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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)

OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. Mar 26, 2025 pm 04:13 PM

Artikel ini membincangkan kelemahan OWASP 10 dalam strategi PHP dan mitigasi. Isu -isu utama termasuk suntikan, pengesahan yang rosak, dan XSS, dengan alat yang disyorkan untuk memantau dan mendapatkan aplikasi PHP.

PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. Mar 25, 2025 am 10:37 AM

Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. Mar 26, 2025 pm 04:18 PM

Artikel ini membincangkan mendapatkan muat naik fail PHP untuk mengelakkan kelemahan seperti suntikan kod. Ia memberi tumpuan kepada pengesahan jenis fail, penyimpanan selamat, dan pengendalian ralat untuk meningkatkan keselamatan aplikasi.

Penyulitan PHP: Penyulitan simetri vs asimetrik. Penyulitan PHP: Penyulitan simetri vs asimetrik. Mar 25, 2025 pm 03:12 PM

Artikel ini membincangkan penyulitan simetri dan asimetrik dalam PHP, membandingkan kesesuaian, prestasi, dan perbezaan keselamatan mereka. Penyulitan simetri lebih cepat dan sesuai untuk data pukal, manakala asimetrik digunakan untuk pertukaran utama yang selamat.

Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Mar 25, 2025 pm 03:06 PM

Artikel ini membincangkan pelaksanaan pengesahan dan kebenaran yang mantap dalam PHP untuk mencegah akses yang tidak dibenarkan, memperincikan amalan terbaik dan mengesyorkan alat peningkatan keselamatan.

PHP API Kadar Mengehadkan: Strategi Pelaksanaan. PHP API Kadar Mengehadkan: Strategi Pelaksanaan. Mar 26, 2025 pm 04:16 PM

Artikel ini membincangkan strategi untuk melaksanakan kadar API yang mengehadkan PHP, termasuk algoritma seperti baldi token dan baldi bocor, dan menggunakan perpustakaan seperti simfoni/kadar-limiter. Ia juga meliputi pemantauan, had kadar penyesuaian secara dinamik, dan tangan

PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. Mar 25, 2025 pm 03:05 PM

Artikel ini membincangkan strategi untuk mencegah serangan CSRF di PHP, termasuk menggunakan token CSRF, kuki tapak yang sama, dan pengurusan sesi yang betul.

Pengesahan Input PHP: Amalan Terbaik. Pengesahan Input PHP: Amalan Terbaik. Mar 26, 2025 pm 04:17 PM

Artikel membincangkan amalan terbaik untuk pengesahan input PHP untuk meningkatkan keselamatan, memberi tumpuan kepada teknik seperti menggunakan fungsi terbina dalam, pendekatan putih, dan pengesahan sisi pelayan.

See all articles