Jadual Kandungan
Mendengar kotak input
Rekod nilai kotak input sebelum dan selepas pengubahsuaian
Rekodkan nilai berbilang kotak input
Ringkasan
Rumah hujung hadapan web Soal Jawab bahagian hadapan input vue mengubah suai nilai sebelum dan selepas

input vue mengubah suai nilai sebelum dan selepas

May 11, 2023 pm 12:35 PM

Vue ialah rangka kerja JavaScript popular yang memudahkan untuk membuat komponen responsif. Dalam pembangunan WEB, kotak input dalam komponen adalah salah satu elemen yang paling biasa. Dalam banyak senario, pembangun perlu menjejaki nilai kotak input dan memprosesnya. Dalam artikel ini, kita akan membincangkan cara mengendalikan nilai kotak input yang diubah suai dalam Vue.

Mendengar kotak input

Vue menyediakan pelbagai cara untuk memantau nilai kotak input. Cara yang paling biasa ialah menggunakan v-model . Arahan v-model melaksanakan pengikatan dua hala, yang bermaksud bahawa pengubahsuaian pada kotak input akan ditunjukkan dalam atribut data dalam contoh komponen, dan apabila nilai atribut data berubah, nilai yang sepadan dalam kotak input akan menjadi dikemas kini secara automatik.

Berikut ialah contoh mudah yang menunjukkan cara menggunakan v-model untuk memantau nilai kotak input teks:

<template>
  <div>
    <label for="username">用户名:</label>
    <input id="username" v-model="username">
    <p>用户名: {{ username }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      username: ""
    };
  }
};
</script>
Salin selepas log masuk

Dalam contoh di atas, kami menggunakan v-model untuk mengikat Kotak input teks dan mengekalkan atribut data username dalam contoh komponen. Apabila pengguna memasukkan nilai dalam kotak input, atribut data username akan dikemas kini secara automatik dan ungkapan perbezaan {{ username }} dalam templat juga akan dikemas kini dengan sewajarnya.

Rekod nilai kotak input sebelum dan selepas pengubahsuaian

Dalam sesetengah senario, kita perlu mengetahui nilai kotak input sebelum dan selepas pengubahsuaian. Contohnya, dalam bentuk, kami mahu dapat menjejaki perubahan yang dibuat oleh pengguna dan menyimpan perubahan ini pada tatasusunan changes untuk kegunaan seterusnya.

Dalam Vue, kami boleh menggunakan watch untuk memantau perubahan dalam atribut data. Apabila nilai atribut data berubah, kita boleh menggunakan fungsi handler untuk melaksanakan beberapa operasi.

Kami boleh menggunakan kod berikut untuk merekodkan nilai diubah suai bagi satu kotak input:

<template>
  <div>
    <label for="username">用户名:</label>
    <input id="username" v-model="username">
    <p>用户名: {{ username }}</p>
    <pre v-text="JSON.stringify(changes)">
<script> export default { data() { return { username: "", changes: [] }; }, watch: { username(newVal, oldVal) { if (newVal !== oldVal) { this.changes.push({ before: oldVal, after: newVal }); } } } }; </script>
Salin selepas log masuk

Dalam kod di atas, kami merekodkan setiap nilai kotak input dengan menambah changes baharu tatasusunan. Kami telah mengubah sedikit fungsi watch dalam pilihan handler supaya ia kini akan dicetuskan apabila nilai kotak input berubah. Apabila nilai baharu tidak sama dengan nilai lama, kami menyimpan nilai sebelumnya dan nilai seterusnya dalam bentuk objek dalam tatasusunan changes.

Rekodkan nilai berbilang kotak input

Dalam pembangunan sebenar, kita biasanya perlu memantau nilai berbilang kotak input. Dalam kes ini, kita boleh menggunakan objek dengan format yang sama untuk menyimpan semua perubahan kotak input. Nama atribut dalam objek ialah ID atau nama kotak input, dan nilai atribut ialah objek yang mengandungi nilai sebelum dan selepas kotak input diubah suai.

<template>
  <div>
    <label for="username">用户名:</label>
    <input id="username" v-model="formData.username">
    <p>用户名: {{ formData.username }}</p>

    <label for="email">邮箱:</label>
    <input id="email" v-model="formData.email">
    <p>邮箱: {{ formData.email }}</p>

    <pre v-text="JSON.stringify(changes)">
<script> export default { data() { return { formData: { username: "", email: "" }, changes: {} }; }, watch: { formData: { handler(newVal, oldVal) { // 遍历对象 formData for (const key in newVal) { // 如果 newValue 和 oldValue 不同 if (newVal[key] !== oldVal[key]) { // 新增一个属性,属性名为输入框的名称或 ID if (!this.changes[key]) { this.$set(this.changes, key, {}); } // 设置属性值, 属性值包含 before 和 after 两个字段 this.changes[key].before = oldVal[key]; this.changes[key].after = newVal[key]; } } }, // 深度监听对象中的属性,当数据属性的值发生改变时,handler 中 callBack 函数将被执行。 deep: true } } }; </script>
Salin selepas log masuk

Dalam kod di atas, kami mengekalkan nilai berbilang kotak input dengan menambah objek data baharu dalam kaedah formData. Kami juga merekodkan semua perubahan dengan menambah objek changes baharu.

Kami mengubah suai fungsi watch dalam pilihan handler supaya ia kini beralih pada formData objek. Apabila ia mengesan bahawa nilai kotak input telah berubah, ia akan menyemak sama ada objek changes sudah wujud dan menetapkan nilai atribut before dan after. Jika kotak input tidak wujud dalam objek changes, atribut baharu akan ditambah.

Kami juga menetapkan atribut watch pilihan deep kepada true, yang akan memantau secara mendalam sifat objek formData supaya apabila nilai dalam kotak input bersarang dalam formData objek , data juga boleh diperhatikan dengan betul.

Ringkasan

Dalam artikel ini, kami membincangkan cara mengendalikan nilai kotak input yang diubah suai dalam Vue. Kami melihat cara menggunakan watch untuk memantau perubahan pada sifat data dan cara mengelog perubahan pada medan input pada objek. Dalam pembangunan sebenar, teknologi ini sangat berguna dan boleh membantu kami menjejaki semua perubahan dalam bentuk dalam masa nyata.

Atas ialah kandungan terperinci input vue mengubah suai nilai sebelum dan selepas. 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)

Peranan React dalam HTML: Meningkatkan Pengalaman Pengguna Peranan React dalam HTML: Meningkatkan Pengalaman Pengguna Apr 09, 2025 am 12:11 AM

React menggabungkan JSX dan HTML untuk meningkatkan pengalaman pengguna. 1) JSX membenamkan HTML untuk menjadikan pembangunan lebih intuitif. 2) Mekanisme DOM maya mengoptimumkan prestasi dan mengurangkan operasi DOM. 3) UI pengurusan berasaskan komponen untuk meningkatkan kebolehkerjaan. 4) Pengurusan negeri dan pemprosesan acara meningkatkan interaktiviti.

React and the Frontend: Membina Pengalaman Interaktif React and the Frontend: Membina Pengalaman Interaktif Apr 11, 2025 am 12:02 AM

React adalah alat pilihan untuk membina pengalaman front-end interaktif. 1) React memudahkan pembangunan UI melalui komponen dan DOM maya. 2) Komponen dibahagikan kepada komponen fungsi dan komponen kelas. Komponen fungsi adalah lebih mudah dan komponen kelas menyediakan lebih banyak kaedah kitaran hayat. 3) Prinsip kerja React bergantung kepada algoritma DOM dan perdamaian maya untuk meningkatkan prestasi. 4) Pengurusan negeri menggunakan useState atau ini. Kaedah kitaran hayat seperti ComponentDidMount digunakan untuk logik tertentu. 5) Penggunaan asas termasuk membuat komponen dan pengurusan negeri, dan penggunaan lanjutan melibatkan cangkuk tersuai dan pengoptimuman prestasi. 6) Kesalahan biasa termasuk kemas kini status yang tidak betul dan isu prestasi, kemahiran debugging termasuk menggunakan reactdevtools dan sangat baik

Komponen React: Membuat unsur -unsur yang boleh diguna semula di HTML Komponen React: Membuat unsur -unsur yang boleh diguna semula di HTML Apr 08, 2025 pm 05:53 PM

Komponen React boleh ditakrifkan oleh fungsi atau kelas, merangkumi logik UI dan menerima data input melalui prop. 1) Tentukan komponen: Gunakan fungsi atau kelas untuk mengembalikan elemen bertindak balas. 2) Rendering Component: React Call Render Kaedah atau Melaksanakan Komponen Fungsi. 3) Komponen multiplexing: Lulus data melalui prop untuk membina UI yang kompleks. Pendekatan kitaran hayat komponen membolehkan logik dilaksanakan pada peringkat yang berbeza, meningkatkan kecekapan pembangunan dan pemeliharaan kod.

Apakah batasan sistem kereaktifan Vue 2 berkenaan dengan perubahan array dan objek? Apakah batasan sistem kereaktifan Vue 2 berkenaan dengan perubahan array dan objek? Mar 25, 2025 pm 02:07 PM

Sistem Reaktiviti Vue 2 bergelut dengan tetapan indeks array langsung, pengubahsuaian panjang, dan penambahan/penghapusan harta benda objek. Pemaju boleh menggunakan kaedah mutasi Vue dan vue.set () untuk memastikan kereaktifan.

Apakah faedah menggunakan TypeScript dengan React? Apakah faedah menggunakan TypeScript dengan React? Mar 27, 2025 pm 05:43 PM

TypeScript meningkatkan pembangunan React dengan menyediakan keselamatan jenis, meningkatkan kualiti kod, dan menawarkan sokongan IDE yang lebih baik, dengan itu mengurangkan kesilapan dan meningkatkan kebolehkerjaan.

React and the Frontend Stack: Alat dan Teknologi React and the Frontend Stack: Alat dan Teknologi Apr 10, 2025 am 09:34 AM

React adalah perpustakaan JavaScript untuk membina antara muka pengguna, dengan komponen terasnya dan pengurusan negeri. 1) Memudahkan pembangunan UI melalui komponen dan pengurusan negeri. 2) Prinsip kerja termasuk perdamaian dan rendering, dan pengoptimuman dapat dilaksanakan melalui React.Memo dan Usememo. 3) Penggunaan asas adalah untuk membuat dan membuat komponen, dan penggunaan lanjutan termasuk menggunakan cangkuk dan konteksapi. 4) Kesalahan biasa seperti kemas kini status yang tidak betul, anda boleh menggunakan ReactDevTools untuk debug. 5) Pengoptimuman prestasi termasuk menggunakan react.memo, senarai virtualisasi dan codesplitting, dan menyimpan kod yang boleh dibaca dan dikekalkan adalah amalan terbaik.

Bagaimanakah anda boleh menggunakan UserEducer untuk Pengurusan Negeri Kompleks? Bagaimanakah anda boleh menggunakan UserEducer untuk Pengurusan Negeri Kompleks? Mar 26, 2025 pm 06:29 PM

Artikel ini menerangkan menggunakan UserEducer untuk Pengurusan Negeri Kompleks dalam React, memperincikan manfaatnya ke atas UseState dan bagaimana untuk mengintegrasikannya dengan useeffect untuk kesan sampingan.

Apakah komponen berfungsi dalam vue.js? Bilakah mereka berguna? Apakah komponen berfungsi dalam vue.js? Bilakah mereka berguna? Mar 25, 2025 pm 01:54 PM

Komponen fungsional dalam vue.js adalah cangkuk kitaran hidup, ringan, dan kekurangan kitaran, sesuai untuk memberikan data tulen dan mengoptimumkan prestasi. Mereka berbeza daripada komponen yang berkesudahan dengan tidak mempunyai keadaan atau kereaktifan, menggunakan fungsi render secara langsung, a

See all articles