Bagaimana untuk melaksanakan senarai berkumpulan dalam Vue?
Bagaimana untuk melaksanakan senarai berkumpulan dalam Vue?
Vue, sebagai rangka kerja bahagian hadapan yang popular, mempunyai sokongan yang baik untuk pemprosesan dan pemaparan data. Dalam aplikasi sebenar, kami sering menghadapi situasi di mana kami perlu memaparkan senarai berkumpulan, seperti memaparkan kategori produk, memaparkan senarai bandar, dsb. Jadi, bagaimana untuk melaksanakan senarai berkumpulan dalam Vue? Mari perkenalkan secara terperinci di bawah.
- Reka bentuk struktur data
Sebelum melaksanakan senarai berkumpulan, kita perlu mereka bentuk struktur data terlebih dahulu. Dalam pelaksanaan Vue, kami biasanya menggunakan tatasusunan untuk menyimpan semua data dan memaparkannya dalam kumpulan. Secara khusus, kita boleh menggunakan tatasusunan objek untuk melaksanakan senarai berkumpulan. Setiap elemen dalam tatasusunan objek mewakili sekeping data dan salah satu atribut mewakili kumpulan yang dimilikinya, seperti:
const data = [ { name: '手机', category: '电子产品' }, { name: '电视', category: '电子产品' }, { name: '冰箱', category: '家用电器' }, { name: '洗衣机', category: '家用电器' }, { name: '自行车', category: '运动健身' }, { name: '跑步机', category: '运动健身' }, ]
Dalam contoh ini, kami menggunakan atribut category
untuk mewakili kumpulan ia kepunyaan. category
属性来表示所属的分组。
- 分组数据处理
在设计好数据结构后,我们需要对数据进行分组处理,以便于后续的展示。在 Vue 中,我们可以通过 computed
计算属性来实现分组处理。具体来说,我们可以定义一个计算属性,将数据按照分组进行归类。代码如下:
computed: { categorizedData() { const result = {} this.data.forEach(item => { if (!result[item.category]) { result[item.category] = [] } result[item.category].push(item) }) return result } }
在这个例子中,我们定义了一个名为 categorizedData
的计算属性,该属性会将数据按照分组进行归类,返回一个包含所有分组数据的对象。其中,我们使用了一个空对象 result
来存储分类后的数据,遍历所有数据,将每个数据加入到其所属的分组中。
- 分组列表渲染
在数据处理完成后,我们需要将分组数据渲染到页面上。在 Vue 中,我们可以使用 v-for
指令来实现列表渲染。具体来说,我们可以在模板中嵌套两层 v-for
指令,遍历分组数据并渲染到页面上。代码如下:
<template> <div> <ul v-for="(items, category) in categorizedData" :key="category"> <li>{{ category }}</li> <ul> <li v-for="item in items" :key="item.name">{{ item.name }}</li> </ul> </ul> </div> </template>
在这个例子中,我们在外层使用 v-for
来遍历分组数据,其中 (items, category) in categorizedData
表示遍历对象中的每个属性和属性值。内层的 v-for
- Pemprosesan data berkumpulan
Selepas mereka bentuk struktur data, kami perlu mengumpulkan data untuk paparan seterusnya. Dalam Vue, kami boleh melaksanakan pemprosesan pengelompokan melalui sifat pengiraan computed
. Secara khusus, kita boleh menentukan atribut yang dikira untuk mengklasifikasikan data ke dalam kumpulan. Kodnya adalah seperti berikut:
<template> <div> <ul v-for="(items, category) in categorizedData" :key="category"> <li>{{ category }}</li> <ul> <li v-for="item in items" :key="item.name">{{ item.name }}</li> </ul> </ul> </div> </template> <script> export default { data() { return { data: [ { name: '手机', category: '电子产品' }, { name: '电视', category: '电子产品' }, { name: '冰箱', category: '家用电器' }, { name: '洗衣机', category: '家用电器' }, { name: '自行车', category: '运动健身' }, { name: '跑步机', category: '运动健身' }, ], } }, computed: { categorizedData() { const result = {} this.data.forEach(item => { if (!result[item.category]) { result[item.category] = [] } result[item.category].push(item) }) return result }, }, } </script>
categorizedData
, yang akan mengelaskan data kepada kumpulan dan mengembalikan objek yang mengandungi semua data terkumpul. Antaranya, kami menggunakan objek kosong hasil
untuk menyimpan data terperingkat, merentasi semua data dan menambah setiap data pada kumpulan yang mana ia berada. 🎜- 🎜Penyampaian senarai kumpulan🎜🎜🎜Selepas pemprosesan data selesai, kami perlu memaparkan data terkumpul ke halaman. Dalam Vue, kita boleh menggunakan arahan
v-for
untuk melaksanakan pemaparan senarai. Secara khusus, kita boleh menyusun dua peringkat arahan v-for
dalam templat untuk melintasi data terkumpul dan menjadikannya pada halaman. Kodnya adalah seperti berikut: 🎜rrreee🎜Dalam contoh ini, kami menggunakan v-for
di lapisan luar untuk melintasi data terkumpul, dengan (item, kategori) dalam categorizedData
bermakna melintasi objek Setiap atribut dan nilai atribut. v-for
dalam digunakan untuk mengulang setiap data terkumpul dan menjadikannya subsenarai. Dengan cara ini, kami boleh memaparkan data terkumpul pada halaman mengikut kategori. 🎜🎜Kod lengkap adalah seperti berikut: 🎜rrreee🎜Dengan kod di atas, kami boleh melaksanakan senarai berkumpulan dalam Vue dan memaparkan data pada halaman mengikut kumpulan. 🎜Atas ialah kandungan terperinci Bagaimana untuk melaksanakan senarai berkumpulan dalam Vue?. 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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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





Menggunakan bootstrap dalam vue.js dibahagikan kepada lima langkah: Pasang bootstrap. Import bootstrap di main.js. Gunakan komponen bootstrap secara langsung dalam templat. Pilihan: Gaya tersuai. Pilihan: Gunakan pemalam.

Anda boleh menambah fungsi ke butang VUE dengan mengikat butang dalam templat HTML ke kaedah. Tentukan kaedah dan tulis logik fungsi dalam contoh Vue.

Terdapat tiga cara untuk merujuk kepada fail JS dalam vue.js: Secara langsung tentukan jalan menggunakan & lt; skrip & gt; tag ;; import dinamik menggunakan cangkuk kitaran hayat yang dipasang (); dan mengimport melalui Perpustakaan Pengurusan Negeri VUEX.

Pilihan Watch di Vue.js membolehkan pemaju mendengar perubahan dalam data tertentu. Apabila data berubah, tontonkan mencetuskan fungsi panggil balik untuk melakukan paparan kemas kini atau tugas lain. Pilihan konfigurasinya termasuk segera, yang menentukan sama ada untuk melaksanakan panggilan balik dengan serta -merta, dan mendalam, yang menentukan sama ada untuk mendengarkan secara rekursif terhadap objek atau tatasusunan.

Pembangunan pelbagai halaman Vue adalah cara untuk membina aplikasi menggunakan rangka kerja VUE.JS, di mana permohonan dibahagikan kepada halaman berasingan: Penyelenggaraan kod: Memisahkan aplikasi ke dalam beberapa halaman boleh menjadikan kod lebih mudah untuk dikendalikan dan diselenggarakan. Modularity: Setiap halaman boleh digunakan sebagai modul yang berasingan untuk penggunaan semula dan penggantian mudah. Routing mudah: Navigasi antara halaman boleh diuruskan melalui konfigurasi penghalaan mudah. Pengoptimuman SEO: Setiap halaman mempunyai URL sendiri, yang membantu SEO.

Vue.js mempunyai empat kaedah untuk kembali ke halaman sebelumnya: $ router.go (-1) $ router.back () menggunakan & lt; router-link to = & quot;/& quot; Komponen Window.History.Back (), dan pemilihan kaedah bergantung pada tempat kejadian.

Terdapat tiga kaedah umum untuk vue.js untuk melintasi tatasusunan dan objek: Arahan V-untuk digunakan untuk melintasi setiap elemen dan membuat templat; Arahan V-mengikat boleh digunakan dengan V-untuk menetapkan nilai atribut secara dinamik untuk setiap elemen; dan kaedah .map boleh menukar elemen array ke dalam tatasusunan baru.

Kaedah untuk melaksanakan lompatan tag dalam Vue termasuk: menggunakan tag dalam templat HTML untuk menentukan atribut HREF. Gunakan komponen router-link routing VUE. Gunakan ini. $ Router.push () kaedah dalam JavaScript. Parameter boleh dilalui melalui parameter pertanyaan dan laluan dikonfigurasikan dalam pilihan penghala untuk lompatan dinamik.
