Dengan pembangunan Internet mudah alih, program kecil dan aplikasi H5 secara beransur-ansur muncul dalam pelbagai senario Sebagai rangka kerja pembangunan yang boleh menyesuaikan diri dengan berbilang platform pada masa yang sama, uniapp mempunyai kelebihan besar dalam pembangunan rentas terminal. Walau bagaimanapun, jika uniapp perlu melepasi sejumlah besar parameter semasa melompat ke halaman, ia mungkin menghadapi beberapa masalah. Perkara berikut akan bermula daripada keperluan sebenar dan memperkenalkan penyelesaian untuk menghantar sejumlah besar parameter pada halaman lompat uniapp.
Dalam projek sebenar, kita mungkin menghadapi senario di mana sejumlah besar data perlu dihantar apabila melompat dari satu halaman ke satu lagi Parameter contoh, halaman butiran pesanan perlu lulus nombor pesanan, status pesanan, masa pesanan, maklumat penerima, maklumat produk, dsb. Jika anda menggunakan kaedah lompat yang disertakan dengan uniapp, iaitu lulus parameter dalam API seperti navigateTo
, anda perlu menggabungkan semua parameter yang perlu dihantar ke objek sebelum melompat, dan kemudian hantar objek ke API sebagai parameter. Kaedah ini sesuai untuk situasi di mana terdapat sedikit parameter, tetapi apabila terdapat terlalu banyak parameter, objek akan menjadi sangat besar dan mungkin melebihi had panjang parameter API.
Untuk menangani masalah di atas, kita boleh menggunakan kaedah yang lebih fleksibel untuk menghantar parameter, iaitu membawa parameter dalam alamat penghalaan Kaedah ini digunakan dalam uniapp Kaedah pelaksanaan adalah seperti berikut:
(1) Apabila melompat, gabungkan semua parameter yang perlu dihantar ke dalam rentetan, dan kemudian tambahkannya sebagai parameter ke alamat penghalaan halaman sasaran.
// 例如目标页面地址为'/pages/order/detail', 我们需要传递的参数如下 var orderId = '123456'; var orderStatus = '已发货'; var orderTime = '2021-01-01'; // 将这些参数拼接在路由地址后面,形成新的跳转地址 var targetUrl = '/pages/order/detail?orderId=' + orderId + '&orderStatus=' + orderStatus + '&orderTime=' + orderTime; // 跳转到目标页面 uni.navigateTo({ url: targetUrl });
(2) Dalam halaman sasaran, gunakan kaedah uni.getQueryParam
untuk mendapatkan parameter yang dibawa dalam alamat lompat.
// 在目标页面中获取跳转地址中携带的参数 var orderId = uni.getQueryParam('orderId'); var orderStatus = uni.getQueryParam('orderStatus'); var orderTime = uni.getQueryParam('orderTime');
Perlu diambil perhatian bahawa kaedah ini hanya boleh mendapatkan parameter yang dibawa dalam alamat penghalaan, tetapi tidak boleh mendapatkan parameter yang melalui API seperti navigateTo
.
Menggunakan alamat penghalaan untuk membawa parameter boleh mengelakkan masalah objek parameter terlalu besar dan melebihi had panjang parameter apabila melepasi terlalu banyak parameter. Tetapi dalam amalan, kita juga perlu memberi perhatian kepada cadangan berikut:
(1) Gabungan parameter harus diseragamkan
Apabila menyambung rentetan parameter, kita harus cuba mengikuti spesifikasi tertentu, seperti nama parameter dan parameter Nilai disambungkan dengan tanda yang sama, dan parameter berbeza disambungkan dengan & Ini memudahkan penghuraian seterusnya parameter dalam halaman sasaran dan mengurangkan kemungkinan ralat.
(2) Bilangan parameter mesti dikawal
Walaupun menggunakan alamat penghalaan untuk membawa parameter secara berkesan boleh mengelakkan masalah yang disebabkan oleh terlalu banyak parameter, kita masih perlu mengawal bilangan parameter, terutamanya dalam program kecil Dalam platform dengan memori kecil dan prestasi lemah seperti H5 dan H5, pemindahan parameter yang tidak perlu harus diminimumkan untuk meningkatkan prestasi dan kestabilan aplikasi.
(3) Jenis data parameter harus dipertimbangkan
Apabila menggunakan alamat penghalaan untuk membawa parameter, semua parameter perlu ditukar kepada bentuk rentetan, jadi selepas mendapatkan parameter dalam halaman sasaran, beberapa perlu menggunakan Penukaran jenis data diperlukan di mana nombor, Boolean dan jenis data lain digunakan.
Ringkasnya, dalam pembangunan uniapp, masalah memindahkan sejumlah besar parameter pada halaman lompat boleh diselesaikan dengan menyambungkan alamat penghalaan, tetapi pembangun masih perlu memberi perhatian kepada spesifikasi, nombor dan jenis data parameter lulus.
Atas ialah kandungan terperinci halaman lompat uniapp melepasi sejumlah besar parameter. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!