Vue mengubah nilai dan melarang pencetus
Dalam Vue.js, melalui pengikatan data dua hala, apabila data komponen berubah, komponen akan dipaparkan semula, tetapi kadangkala kami tidak mahu beberapa perubahan data mencetuskan pemaparan semula bagaimana untuk melarang perubahan Vue Nilai mencetuskan pemaparan semula.
Data dalam Vue adalah responsif
Data dalam rangka kerja Vue adalah responsif. Ini bermakna apabila data ditukar, Vue akan memaparkan semula data baharu dalam paparan. Ciri ini menjadikan pembangunan halaman lebih mudah dan lancar.
Sebagai contoh, apabila data berubah, komponen Vue berikut akan dipaparkan semula secara automatik:
<template> <div> <p>{{ message }}</p> <button @click="changeMessage">Click me to change message</button> </div> </template> <script> export default { data() { return { message: "Hello world", }; }, methods: { changeMessage() { this.message = "Hello Vue.js"; }, }, }; </script>
Dalam kod di atas, mesej ialah data responsif Vue, tetapi setiap kali butang Tukar Mesej adalah diklik Menyebabkan keseluruhan komponen dipaparkan semula, yang boleh menjejaskan prestasi. Inilah cara untuk mengelakkan perkara ini.
Gunakan kaedah $forceUpdate
Vue menyediakan kaedah komponen $forceUpdate() yang boleh memaksa komponen untuk dipaparkan semula. Walau bagaimanapun, kaedah $forceUpdate() tidak mencetuskan pemaparan semula secara mendalam. Ini bermakna jika anda menukar sekeping data, Vue hanya akan memaparkan semula komponen dan subkomponen yang mengandungi data tersebut.
Jika anda memanggil $forceUpdate() semasa kitaran pemaparan komponen, komponen akan memaparkan semula keseluruhan komponen, walaupun data tidak berubah. Oleh itu, kita boleh menghalang komponen daripada membuat dengan memanggil kaedah $forceUpdate() apabila data berubah. Contohnya:
<template> <div> <p>{{ message }}</p> <button @click="changeMessage">Click me to change message</button> </div> </template> <script> export default { data() { return { message: "Hello world", }; }, methods: { changeMessage() { this.message = "Hello Vue.js"; this.$forceUpdate(); }, }, }; </script>
Dalam contoh di atas, kami memanggil kaedah $forceUpdate() sambil mengubah suai mesej data Dengan cara ini, Vue hanya akan memaparkan semula komponen tanpa menjejaskan prestasi komponen lain.
Gunakan kaedah vue-set
Vue menyediakan kaedah vue-set yang boleh menambah atau mengemas kini sifat responsif baharu pada objek. Kaedah ini biasanya digunakan untuk menambah elemen dom baharu, atau mengawal beberapa elemen yang tidak perlu dipaparkan dalam kitaran Vue. Menggunakan vue-set boleh mengelakkan masalah prestasi yang disebabkan oleh panggilan berulang untuk forceUpdate:
<template> <div> <p>The message start with "{{ message.charAt(0) }}"</p> <button @click="prependChar">Click me to add new char</button> </div> </template> <script> import {set} from 'vue' export default { data() { return { message: "Hello world", }; }, methods: { prependChar() { const newChar = String.fromCharCode( this.message.charCodeAt(0) + 1 ); set(this.message, 0, newChar); }, }, }; </script>
Dalam kod di atas, apabila kami mengklik butang, aksara baharu ditambahkan pada permulaan mesej dan menggunakan kaedah yang ditetapkan untuk memberitahu Vue untuk menambah sifat reaktif baharu supaya isu prestasi dengan kaedah forceUpdate dapat dielakkan.
Pemikiran Akhir
Dalam Vue, menukar data responsif akan mencetuskan pemaparan semula komponen, yang boleh menjadikan pembangunan kami lebih lancar. Tetapi kadangkala kita perlu mengurangkan bilangan pemaparan semula untuk meningkatkan prestasi halaman. Dalam artikel ini kami memperkenalkan cara untuk menghalang pemaparan komponen dengan memanggil kaedah $forceUpdate dan kaedah vue-set. Pada masa yang sama, kita perlu memberi perhatian kepada isu prestasi dan kecekapan kod, dan memilih kaedah yang sesuai untuk melaksanakan fungsi melumpuhkan pencetus perubahan nilai.
Atas ialah kandungan terperinci Vue mengubah nilai dan melarang pencetus. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Artikel ini membincangkan useeffect dalam React, cangkuk untuk menguruskan kesan sampingan seperti pengambilan data dan manipulasi DOM dalam komponen berfungsi. Ia menerangkan penggunaan, kesan sampingan yang biasa, dan pembersihan untuk mencegah masalah seperti kebocoran memori.

Lazy memuatkan kelewatan memuatkan kandungan sehingga diperlukan, meningkatkan prestasi web dan pengalaman pengguna dengan mengurangkan masa beban awal dan beban pelayan.

Fungsi pesanan yang lebih tinggi dalam JavaScript meningkatkan ketabahan kod, kebolehgunaan semula, modulariti, dan prestasi melalui abstraksi, corak umum, dan teknik pengoptimuman.

Artikel ini membincangkan kari dalam JavaScript, teknik yang mengubah fungsi multi-argumen ke dalam urutan fungsi argumen tunggal. Ia meneroka pelaksanaan kari, faedah seperti aplikasi separa, dan kegunaan praktikal, meningkatkan kod baca

Artikel ini menerangkan algoritma perdamaian React, yang dengan cekap mengemas kini DOM dengan membandingkan pokok DOM maya. Ia membincangkan manfaat prestasi, teknik pengoptimuman, dan kesan terhadap pengalaman pengguna. Kira -kira: 159

Artikel ini menerangkan USEContext dalam React, yang memudahkan pengurusan negara dengan mengelakkan penggerudian prop. Ia membincangkan faedah seperti keadaan terpusat dan penambahbaikan prestasi melalui pengurangan semula yang dikurangkan.

Artikel membincangkan penyambungan komponen reaksi ke kedai redux menggunakan Connect (), menerangkan MapStateToprops, MapdispatchToprops, dan kesan prestasi.

Artikel membincangkan menghalang tingkah laku lalai dalam pengendali acara menggunakan kaedah pencegahanDefault (), faedahnya seperti pengalaman pengguna yang dipertingkatkan, dan isu -isu yang berpotensi seperti kebimbangan aksesibiliti.
