Rumah pembangunan bahagian belakang masalah PHP Bagaimana untuk menghantar array ke js dalam php

Bagaimana untuk menghantar array ke js dalam php

Apr 20, 2023 am 09:10 AM

Pengiriman data antara PHP dan JavaScript ialah topik penting dalam pembangunan web, yang melibatkan pelbagai kaedah berbeza, tetapi menghantar tatasusunan masih menjadi isu penting, memandangkan kedua-dua PHP dan JS mempunyai struktur data dan ciri bahasa yang berbeza, isu ini boleh menjadi rumit. Walau bagaimanapun, menggunakan beberapa helah yang mudah dan berkesan, anda boleh dengan mudah menghantar tatasusunan antara PHP dan JS. Dalam artikel ini, saya akan memperkenalkan anda kepada beberapa teknik untuk menghantar tatasusunan daripada PHP ke JS, saya harap ia akan membantu anda.

Kaedah 1: Gunakan json_encode()

JSON ialah format data ringan yang digunakan secara meluas untuk penghantaran data antara aplikasi web. PHP menyediakan fungsi terbina dalam yang dipanggil json_encode(), yang boleh mensiri tatasusunan PHP ke dalam format JSON dan kemudian menghantarnya kepada JS. Format JSON sangat mudah untuk dihuraikan dan dijana kerana ia adalah teks biasa dan tidak memerlukan sebarang tempat tertentu. Di bawah ialah skrip PHP mudah yang menggunakan kaedah json_encode() untuk menukar tatasusunan kepada format JSON:

<?php
    $arr = array("apple", "banana", "orange");
    $json = json_encode($arr);
    echo $json;
?>
Salin selepas log masuk

Ini akan mengeluarkan rentetan yang serupa dengan:

["apple","banana","orange"]
Salin selepas log masuk

Sekarang, anda boleh menggunakan penghurai JSON terbina dalam JavaScript (JSON.parse()) untuk menghuraikan rentetan ke dalam tatasusunan JS:

<script>
    var jsArray = JSON.parse('<?php echo $json; ?>');
</script>
Salin selepas log masuk

Kaedah 2: Gunakan Ajax

Ajax (JavaScript Asynchronous dan XML ) ialah teknologi JavaScript dan XML tak segerak yang membolehkan anda menghantar permintaan tak segerak kepada pelayan untuk mendapatkan data tanpa perlu memuat semula keseluruhan halaman. Apabila menggunakan Ajax, anda boleh mengeksport data tatasusunan yang diproses oleh PHP ke dalam data format XML dan menghantarnya kepada JS melalui Ajax.

Pertama, anda perlu menggunakan PHP untuk menukar tatasusunan kepada rentetan format XML dan kemudian mengembalikannya kepada permintaan Ajax:

<?php
    $arr = array("apple", "banana", "orange");

    $xml = new SimpleXMLElement('<root/>');
    array_walk_recursive($arr, array ($xml, 'addChild'));
    echo $xml->asXML();
?>
Salin selepas log masuk

Dalam JS, anda perlu menggunakan Ajax ( XMLHttpRequest object ) untuk mendapatkan data dalam format XML:

<script>
    var xhttp = new XMLHttpRequest();
    xhttp.onreadystatechange = function() {
        if (this.readyState == 4 && this.status == 200) {
            var xmlDoc = this.responseXML;
            var jsArray = Array.from(xmlDoc.getElementsByTagName("root")[0].childNodes).map(function(node){return node.firstChild.nodeValue;});
        }
    };
    xhttp.open("GET", "array_to_xml.php", true);
    xhttp.send();
</script>
Salin selepas log masuk

Kaedah 3: Gunakan medan tersembunyi

Teknik ini adalah untuk menghantar data tatasusunan PHP ke halaman HTML, dan kemudian menggunakan medan tersembunyi untuk dapatkannya dalam data JS. Elemen borang HTML (contohnya, elemen input) semuanya mempunyai atribut nilai yang dipanggil, yang membolehkan anda menghantar nilai kepada pelayan apabila borang diserahkan. Begitu juga, anda boleh menghantar data tatasusunan ke dalam medan tersembunyi pada halaman HTML dan mendapatkannya melalui JS. Berikut ialah satu cara untuk menggunakan medan tersembunyi:

<?php
    $arr = array("apple", "banana", "orange");
?>
<input type="hidden" id="php_array" value="<?php echo implode(",", $arr); ?>">
<script>
    var jsArr = document.getElementById("php_array").value.split(",");
</script>
Salin selepas log masuk

Dalam contoh ini, kod PHP memisahkan nilai dalam tatasusunan dengan koma dan kemudian menggunakannya sebagai nilai medan tersembunyi. Dalam JS anda boleh menggunakan atribut nilai untuk mengekstrak nilai dan mengumpulkannya ke dalam tatasusunan.

Kaedah 4: Gunakan pembolehubah JavaScript

Kaedah ini adalah untuk menghantar data tatasusunan PHP kepada kod JavaScript dan menggunakan pembolehubah JavaScript untuk menyimpan data tatasusunan. PHP menulis data tatasusunan sebagai rentetan kod JS dan kemudian mengeluarkannya ke penyemak imbas. JS boleh menggunakan rentetan untuk menjana tatasusunan. Berikut ialah contoh penggunaan pembolehubah JavaScript:

<?php
    $arr = array("apple", "banana", "orange");
    $js_array = json_encode($arr);
?>
<script>
    var jsArr = <?php echo $js_array; ?>;
</script>
Salin selepas log masuk

Dalam contoh ini, PHP menggunakan kaedah json_encode() untuk menukar tatasusunan kepada format JSON dan kemudian menulisnya sebagai rentetan kod JS. Kod JS boleh terus menggunakan pembolehubah jsArr untuk mendapatkan data tatasusunan.

Dalam artikel ini, kami memperkenalkan secara ringkas cara PHP menghantar tatasusunan kepada JS. Anda boleh menggunakan pelbagai teknik untuk menghantar data daripada PHP ke JS, tetapi salah satu kaedah yang paling popular dan praktikal ialah menggunakan Notasi Objek JavaScript JSON. JSON membolehkan anda menukar tatasusunan PHP kepada tatasusunan JS dengan mudah dan membantu anda mencapai pemindahan data yang lancar antara PHP dan JS.

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

Tag artikel 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)

Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Mar 10, 2025 pm 06:16 PM

Apakah piawaian pengekodan PHP terkini dan amalan terbaik?

Bagaimana saya bekerja dengan sambungan php dan pecl? Bagaimana saya bekerja dengan sambungan php dan pecl? Mar 10, 2025 pm 06:12 PM

Bagaimana saya bekerja dengan sambungan php dan pecl?

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Mar 10, 2025 pm 06:15 PM

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP?

Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:50 PM

Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php

Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Mar 03, 2025 pm 04:47 PM

Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi?

Apakah amalan terbaik untuk deduplikasi tatasusunan php Apakah amalan terbaik untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:41 PM

Apakah amalan terbaik untuk deduplikasi tatasusunan php

Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Mar 03, 2025 pm 04:51 PM

Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama?

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Mar 10, 2025 pm 06:12 PM

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP?

See all articles