Rumah > hujung hadapan web > Soal Jawab bahagian hadapan > Tambah, padam, ubah suai dan semak halaman senarai vue

Tambah, padam, ubah suai dan semak halaman senarai vue

王林
Lepaskan: 2023-05-11 09:47:06
asal
942 orang telah melayarinya

Apabila Vue.js menjadi semakin popular, pasti akan terdapat lebih banyak permintaan untuk aplikasi Vue. Memandangkan kepentingan halaman senarai terus meningkat dalam kebanyakan aplikasi web, penambahan halaman senarai Vue, pemadaman dan pengubahsuaian bukan sahaja menjadi keperluan aplikasi yang sangat penting, tetapi juga salah satu perkara terpenting yang harus dipelajari oleh pelajar Vue. Artikel ini akan memperkenalkan cara menggunakan Vue.js untuk melakukan operasi tambah, padam, ubah suai dan semak asas pada halaman senarai.

Persediaan:

Sebelum memulakan artikel ini, sila pastikan anda mempunyai pemahaman yang mencukupi tentang asas HTML dan JavaScript, kerana kami akan menggunakan Vue.js, HTML dan JavaScript untuk membuat senarai program aplikasi.

Artikel ini merangkumi topik berikut:

1 Mencipta aplikasi Vue

2. Membuat senarai

3

4. Edit entri

5. Padam entri

1. Buat aplikasi Vue

Kita perlu memasang Vue.js. Ia boleh dipasang melalui CDN atau melalui pengurus pakej npm. Jika anda ingin memasang melalui CDN, anda boleh mendapatkannya daripada: https://unpkg.com/vue@next/dist/vue.global.js. Jika anda ingin memasang menggunakan pengurus pakej npm, anda boleh menggunakan arahan berikut dalam terminal:

npm install vue
Salin selepas log masuk

Setelah pemasangan selesai, kini kita boleh mencipta contoh Vue seperti berikut:

const app = Vue.createApp({
});
Salin selepas log masuk

Seterusnya, kami akan menentukan templat, data, kaedah dan sifat yang dikira dalam contoh.

2. Buat senarai

Kami akan menggunakan arahan v-for untuk menggelungkan data senarai. Katakan kita mempunyai tatasusunan yang menyimpan data item senarai. Kita boleh mengisytiharkan tatasusunan ini sebagai model data dalam contoh Vue seperti berikut:

const app = Vue.createApp({
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' },
        { id: 4, name: 'Item 4' },
        { id: 5, name: 'Item 5' }
      ]
    }
  }
});
Salin selepas log masuk

Sekarang, kita perlu menggunakan arahan v-untuk dalam templat untuk melelar melalui tatasusunan ini dan memaparkan data bagi setiap item. Untuk melakukan ini, kami akan menambah kod berikut pada templat Vue:

<template>
  <ul>
    <li v-for="item in items" :key="item.id">{{ item.name }}</li>
  </ul>
</template>
Salin selepas log masuk

Kod di atas akan menggelung melalui tatasusunan data menggunakan arahan v-for dan menyediakan pengecam unik untuk setiap elemen item menggunakan kata kunci: kunci.

Sekarang kami telah selesai membuat senarai.

3. Tambah item baharu

Kami akan menggunakan perintah

yang disediakan oleh Vue untuk membuat input senarai baharu dan borang penyerahan. Arahan v-model membenarkan mengikat nilai input ke komponen Vue. Menggunakan arahan v-model sebenarnya ialah cara kami biasanya menggunakan kotak input teks, dan ia akan mengemas kini pengikatan data dua hala secara automatik. v-model

Untuk menambah item senarai baharu, kami perlu memaparkan borang dan mengumpul data baharu daripada borang. Kami mencipta borang dengan Vue.js seperti ini:

<template>
  <div>
    <form @submit.prevent="addItem">
      <input type="text" v-model="newItem" placeholder="Add a new item">
      <button type="submit">Add</button>
    </form>
  </div>
</template>
Salin selepas log masuk

Kami menggunakan

pengubah suai acara pada borang supaya borang itu tidak pernah benar-benar diserahkan. Sebaliknya, ia mencetuskan pengendali acara yang kita terikat kepada kaedah @submit.prevent. Kaedah ini akan menambah item baharu pada tatasusunan data. addItem

Bagaimanakah perintah

terikat pada kotak teks tersimpan input? Kita perlu mentakrifkan pembolehubah baharu v-model dalam model data komponen Vue seperti berikut: newItem

const app = Vue.createApp({
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' },
        { id: 4, name: 'Item 4' },
        { id: 5, name: 'Item 5' }
      ],
      newItem: ''
    }
  },
  methods: {
    addItem() {
      this.items.push({id: this.items.length + 1, name: this.newItem});
      this.newItem = '';
    }
  }
});
Salin selepas log masuk

Dalam kaedah

, kami memasukkan objek item baharu pada penghujung tatasusunan dan menyediakan Baharu objek projek diberi ID unik. Selepas menambah item, kami akan menetapkan semula addItem dengan rentetan kosong. Kini kami telah melaksanakan fungsi menambah item baharu pada tatasusunan. newItem

4. Edit item

Matlamat kami sekarang ialah menambah butang edit pada setiap item Apabila butang diklik, nama item boleh diubah suai. Cara untuk mencapai fungsi penyuntingan ini ialah dengan mengikat

pada item semasa dalam model data dan memaparkan butang simpan. Anda boleh meletakkan butang edit di sebelah setiap item yang bertukar kepada mod edit apabila diklik. v-model

Pertama, kita perlu mentakrifkan pembolehubah

. Pembolehubah ini akan menentukan item yang sedang diedit. Kita juga perlu mentakrifkan pembolehubah currentItem untuk menyembunyikan nama entri dalam mod edit seperti ini: editing

const app = Vue.createApp({
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' },
        { id: 4, name: 'Item 4' },
        { id: 5, name: 'Item 5' }
      ],
      newItem: '',
      editing: false,
      currentItem: null
    }
  },
  methods: {
    addItem() {
      this.items.push({id: this.items.length + 1, name: this.newItem});
      this.newItem = '';
    },
    editItem(item) {
      this.editing = true;
      this.currentItem = item;
    },
    saveItem() {
      this.editing = false;
      this.currentItem = null;
    }
  }
});
Salin selepas log masuk

Sekarang kita perlu menunjukkan butang edit dalam setiap elemen item. Apabila butang edit diklik, kita perlu beralih ke mod edit supaya kita boleh mula mengedit projek semasa. Kami boleh menetapkan butang edit untuk setiap item menggunakan kod berikut:

<template>
  <ul>
    <li v-for="item in items" :key="item.id">
      <span v-if="!editing || currentItem !== item">{{ item.name }}</span>
      <span v-else><input type="text" v-model="currentItem.name"></span>
      <button @click="editItem(item)" v-if="!editing">Edit</button>
      <button @click="saveItem()" v-if="editing">Save</button>
    </li>
  </ul>
</template>
Salin selepas log masuk

Kami menogol elemen teks sandaran dan mengedit kotak input teks untuk menunjukkan atau menyembunyikan nama item dengan menggunakan arahan

. Apabila kami menggunakan mod edit, masukkan atau edit nama projek dalam kotak teks edit. Mod edit boleh keluar dengan mengklik butang Simpan. v-if

5. Padam item

Kami kini perlu menambah fungsi untuk memadam item. Kita perlu menambah butang padam untuk setiap item. Apabila butang padam diklik, kami akan memadamkan item ini daripada tatasusunan data. Kami akan menggunakan kaedah Array.prototype.indexOf() JavaScript untuk mencari dan memadam item.

const app = Vue.createApp({
  data() {
    return {
      items: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' },
        { id: 4, name: 'Item 4' },
        { id: 5, name: 'Item 5' }
      ],
      newItem: '',
      editing: false,
      currentItem: null
    }
  },
  methods: {
    addItem() {
      this.items.push({id: this.items.length + 1, name: this.newItem});
      this.newItem = '';
    },
    editItem(item) {
      this.editing = true;
      this.currentItem = item;
    },
    saveItem() {
      this.editing = false;
      this.currentItem = null;
    },    
    deleteItem(item) {
      const index = this.items.indexOf(item);
      if (index > -1) {
        this.items.splice(index, 1);
      }
    }
  }
});
Salin selepas log masuk

Kini kita boleh menambah butang padam pada setiap item. Apabila butang padam diklik, kita boleh memanggil kaedah deleteItem().

<template>
  <ul>
    <li v-for="item in items" :key="item.id">
      <span v-if="!editing || currentItem !== item">{{ item.name }}</span>
      <span v-else><input type="text" v-model="currentItem.name"></span>
      <button @click="editItem(item)" v-if="!editing">Edit</button>
      <button @click="saveItem()" v-if="editing">Save</button>
      <button @click="deleteItem(item)">Delete</button>
    </li>
  </ul>
  <div>
    <form @submit.prevent="addItem">
      <input type="text" v-model="newItem" placeholder="Add a new item">
      <button type="submit">Add</button>
    </form>
  </div>
</template>
Salin selepas log masuk

Kami telah mempelajari cara menggunakan Vue.js untuk menambah, memadam, mengubah suai dan menyemak halaman senarai. Kesederhanaan dan kemudahan penggunaan Vue menjadikannya pilihan yang sangat berkuasa untuk mengendalikan kebanyakan operasi dengan mudah untuk aplikasi senarai.

Vue bukan sahaja menjadikan kod lebih mudah difahami, tetapi juga membolehkan kami membuat aplikasi web yang berkuasa dengan cepat. Membuat halaman senarai untuk mana-mana projek telah menjadi lebih mudah dengan bantuan Vue.js.

Atas ialah kandungan terperinci Tambah, padam, ubah suai dan semak halaman senarai vue. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan