Apabila menggunakan uniapp untuk membangunkan projek, kami sering menghadapi senario di mana kami perlu melepasi parameter dan melompat ke halaman seterusnya. Walau bagaimanapun, apabila menghadapi situasi di mana halaman perlu dimuat semula, sesetengah pembangun mendapati halaman itu tidak dimuat semula seperti yang diharapkan.
Punca masalah ini terletak pada mekanisme lompat halaman uniapp dan mekanisme kemas kini komponen halaman. Untuk menangani masalah ini, kita perlu mengetahui perkara berikut:
Dalam uniapp, lompatan halaman dilaksanakan melalui kaedah seperti uni.navigateTo
. Apabila membuat lompatan halaman, halaman baharu tidak akan memuatkan semula keseluruhan halaman seperti dalam H5, tetapi hanya akan melaksanakan semula fungsi kitaran hayat.
Jika anda tidak tahu tentang fungsi kitaran hayat uniapp, anda boleh menyemak [dokumentasi rasmi](https://uniapp.dcloud.io/frame?id=%e7%94%9f%e5%91 %bd%e5 %91%a8%e6%9c%9f). Secara ringkasnya, fungsi kitaran hayat dalam uniapp termasuk onLoad
, onShow
, onReady
, onHide
dan onUnload
masing-masing fungsi ini mewakili pemuatan halaman, paparan halaman, penyiapan pemaparan awal halaman dan penyembunyian halaman . dan pemunggahan halaman dan keadaan lain yang berbeza.
Oleh itu, jika kami perlu mengemas kini data selepas melompat ke halaman baharu, kami harus melakukan operasi yang berkaitan dalam onShow
fungsi kitaran hayat halaman baharu dan bukannya mengharapkan halaman dimuat semula secara automatik apabila melompat.
Dalam uniapp, komponen dalam halaman mempunyai mekanisme kemas kini data mereka sendiri. Jika kita perlu memuat semula komponen pada halaman, kita perlu mencetuskan kaedah this.$forceUpdate()
komponen secara manual.
Sebagai contoh, dalam onShow
fungsi kitaran hayat halaman, kita perlu mengemas kini komponen senarai dalam halaman, yang boleh dilaksanakan seperti ini:
onShow() { // 获取最新数据 const newData = getData(); // 更新组件数据 this.$refs.list.data = newData; // 强制刷新列表 this.$refs.list.$forceUpdate(); }
Sepatutnya ambil perhatian bahawa jika kemas kini diperlukan Sifat lain komponen (seperti gaya, dll.) perlu dilaksanakan dengan mengikat pembolehubah pada komponen atau menggunakan sifat yang dikira.
Melalui analisis dua perkara di atas, kita boleh membuat kesimpulan yang sangat penting apabila membangunkan halaman uniapp: apabila membuat lompatan halaman, anda tidak seharusnya menjangkakan bahawa halaman akan dimuat semula secara automatik, tetapi harus berada di halaman baharu onShow
Kemas kini data dalam fungsi kitaran hayat. Pada masa yang sama, jika anda perlu memuat semula komponen, anda perlu mencetuskan kaedah $forceUpdate()
komponen secara manual.
Secara keseluruhannya, uniapp ialah rangka kerja merentas platform yang sangat baik dengan fleksibiliti dan skalabiliti, tetapi ia juga memerlukan kami memahami mekanismenya yang mendalam semasa proses pembangunan, terutamanya dalam aspek kemas kini data dan lonjakan halaman , beri perhatian lebih kepada butiran.
Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan masalah yang halaman uniapp melompat dengan parameter tetapi tidak memuat semula. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!