cari
Rumahhujung hadapan webView.jsAmalan komponen Vue: pembangunan komponen halaman

Amalan komponen Vue: pembangunan komponen halaman

Nov 24, 2023 am 08:56 AM
vuekomponenpenomboran

Amalan komponen Vue: pembangunan komponen halaman

Amalan komponen Vue: pembangunan komponen halaman

Pengenalan

Dalam aplikasi web, fungsi halaman adalah komponen penting. Komponen paging yang baik hendaklah ringkas dan jelas dalam persembahan, kaya dengan fungsi, dan mudah untuk disepadukan dan digunakan.

Dalam artikel ini, kami akan memperkenalkan cara menggunakan rangka kerja Vue.js untuk membangunkan komponen halaman yang sangat boleh disesuaikan. Kami akan menerangkan secara terperinci cara membangunkan menggunakan komponen Vue melalui contoh kod.

Timbunan teknologi

  • Vue.js 2.x
  • JavaScript (ES6)
  • HTML5 dan CSS3

Persekitaran pembangunan

  • v8Node.js.
  • V ue.js v2 .5.2
Keperluan komponen penomboran

    Terima jumlah halaman (jumlah) dan bilangan halaman semasa (semasa) melalui props
  • Anda boleh mengkonfigurasi bilangan maksimum halaman yang dipaparkan (maxShown)
  • konfigurasikan teks yang dipaparkan oleh butang (prevTeks dan nextTeks) dan gaya butang
  • Klik nombor halaman untuk beralih ke halaman yang sepadan
  • Nombor halaman semasa diserlahkan
  • Apabila halaman semasa tidak mempunyai halaman sebelumnya, klik acara butang halaman sebelumnya diabaikan
  • Apabila halaman semasa tidak mempunyai halaman seterusnya, abaikan acara klik butang halaman seterusnya
Idea reka bentuk dan pelaksanaan kod

Mengikut keperluan, kami membahagikan komponen halaman kepada beberapa komponen kecil untuk pelaksanaan. Kita perlu mencipta 3 komponen kecil berikut:

    Pagination.vue
komponen halaman utama, yang bertanggungjawab untuk memproses data penomboran dan logik. Hantar maklumat paging kepada subkomponen dan balas peristiwa subkomponen.

    Button.vue
Komponen ini ialah komponen butang, digunakan untuk membuat butang paging.

    Page.vue
Komponen ini digunakan untuk membuat satu blok halaman, termasuk label halaman dan status. Blok halaman boleh menjadi halaman semasa atau halaman bukan semasa.

Seterusnya, mari kita gunakan kod untuk melaksanakan 3 komponen di atas.

    Pagination.vue
  1. <template>
      <div class="pagination-container">
        <button-prev :current="current" @onPrev="prev"></button-prev>
        <page v-for="page in pages"
          :key="page"
          :page="page"
          :is-selected="page === current"
          @on-page-selected="selectPage"></page>
        <button-next :current="current" :total="total" @onNext="next"></button-next>
      </div>
    </template>
    <script>
    import ButtonPrev from './ButtonPrev.vue';
    import ButtonNext from './ButtonNext.vue';
    import Page from './Page.vue';
    
    export default {
      components: { ButtonPrev, ButtonNext, Page },
      props: {
        total: {
          type: Number,
          default: 10
        },
        current: {
          type: Number,
          default: 1
        },
        maxShown: {
          type: Number,
          default: 5
        },
        prevText: {
          type: String,
          default: '上一页'
        },
        nextText: {
          type: String,
          default: '下一页'
        }
      },
      computed: {
        pages () {
          const start = Math.max(1, this.current - Math.floor(this.maxShown / 2));
          const end = Math.min(this.total, start + this.maxShown - 1);
          return Array.from({ length: end - start + 1 }, (v, k) => start + k);
        }
      },
      methods: {
        selectPage (page) {
          if (this.current === page) return;
          this.current = page;
          this.$emit('onPageChanged', page);
        },
        prev () {
          if (this.current > 1) {
            this.selectPage(this.current - 1);
          }
        },
        next () {
          if (this.current < this.total) {
            this.selectPage(this.current + 1);
          }
        }
      }
    }
    </script>
Dalam kod di atas, kami mula-mula mengimport komponen ButtonPrev, ButtonNext dan Page. Seterusnya, atribut jumlah, semasa, maxShown, prevText dan nextText diperoleh menggunakan prop, dan halaman atribut yang dikira ditakrifkan Berdasarkan nombor halaman semasa (semasa) dan nombor halaman maksimum (maxShown), tatasusunan yang mengandungi nombor halaman diperolehi untuk digunakan dalam komponen.

Kami juga mentakrifkan kaedah selectPage, di mana jika nombor halaman (halaman) adalah sama dengan nombor halaman semasa (semasa), kembali atau tidak melakukan apa-apa. Jika tidak, nombor halaman baharu dipancarkan kepada komponen induk. Kaedah

sebelumnya() dan seterusnya() digunakan untuk mengendalikan acara halaman sebelumnya dan halaman seterusnya dan menghalang acara daripada dibalas.

    ButtonPrev.vue
  1. <template>
        <button
          class="btn-previous"
          :disabled="current === 1"
          @click="onPrev()">
          {{ prevText }}
        </button>
    </template>
    
    <script>
    export default {
      props: {
        prevText: {
          type: String,
          default: '上一页'
        },
        current: {
          type: Number,
          default: 1
        }
      },
      methods: {
        onPrev () {
          this.$emit('onPrev');
        }
      }
    }
    </script>
    
    <style scoped>
    .btn-previous {
      border: none;
      color: #333;
      display: inline-block;
      font-size: 16px;
      padding: 6px 12px;
      margin-right: 5px;
      background-color:#fff;
      cursor: pointer;
      border-radius: 2px;
      box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1);
    }
    .btn-previous:disabled {
      color: #ccc;
      cursor: default;
    }
    </style>
Dalam kod di atas, kami mula-mula mendapatkan nombor halaman semasa (semasa) dan atribut teks (prevTeks) butang halaman sebelumnya melalui prop. Dalam templat, gunakan pengikatan kelas (dilumpuhkan) untuk mengawal keadaan penggunaan butang. Kaedah onPrev ditakrifkan, yang mencetuskan peristiwa onPrev komponen induk.

    ButtonNext.vue
  1. <template>
        <button
          class="btn-next"
          :disabled="current === total"
          @click="onNext()">
          {{ nextText }}
        </button>
    </template>
    
    <script>
    export default {
      props: {
        total: {
          type: Number,
          default: 10
        },
        nextText: {
          type: String,
          default: '下一页'
        },
        current: {
          type: Number,
          default: 1
        }
      },
      methods: {
        onNext () {
          this.$emit('onNext');
        }
      }
    }
    </script>
    
    <style scoped>
    .btn-next {
      border: none;
      color: #333;
      display: inline-block;
      font-size: 16px;
      padding: 6px 12px;
      margin-left: 5px;
      background-color: #fff;
      cursor: pointer;
      border-radius: 2px;
      box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1);
    }
    .btn-next:disabled {
      color: #ccc;
      cursor: default;
    }
    </style>
Dalam kod di atas, kami menyalin kod ButtonPrev.vue dan menukar sedikit teks dan syarat penghakiman.

    Page.vue
  1. <template>
      <button :class="{ current: isSelected }" class="btn-page" @click="onPageSelected(page)">
        {{ page }}
      </button>
    </template>
    
    <script>
    export default {
      props: {
        page: {
          type: Number,
          required: true
        },
        isSelected: {
          type: Boolean,
          default: false
        }
      },
      methods: {
        onPageSelected () {
          this.$emit('onPageSelected', this.page);
        }
      }
    }
    </script>
    
    <style scoped>
    .btn-page {
      border: none;
      color: #333;
      display: inline-block;
      font-size: 16px;
      padding: 6px 12px;
      margin-left: 5px;
      background-color: #fff;
      cursor: pointer;
      border-radius: 2px;
      box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.1);
    }
    .btn-page.current {
      background-color: #0078d7;
      color: #fff;
    }
    </style>
Dalam kod di atas, kami memperoleh nilai nombor halaman (halaman) dan atribut isSelected bagi butang melalui prop. Dalam templat, gunakan pengikatan kelas ("semasa") untuk menyerlahkan halaman yang dipilih.

Kami juga mentakrifkan kaedah onPageSelected, yang mencetuskan peristiwa onPageSelected komponen induk.

Akhir sekali, komponen ini boleh digunakan dalam templat dalam mana-mana aplikasi Vue.js, seperti yang ditunjukkan di bawah:

<template>
  <div>
    <pagination
      :total="total"
      :current="current"
      :maxShown="maxShown"
      :prevText="prevText"
      :nextText="nextText"
      @onPageChanged="onPageChanged"></pagination>
    <ul>
      <li v-for="(item, index) in items" :key="index">{{ item.name }}</li>
    </ul>
  </div>
</template>

<script>
import Pagination from './Pagination.vue';

export default {
  components: {
    Pagination
  },
  data () {
    return {
      current: 1,
      maxShown: 10,
      prevText: '上一页',
      nextText: '下一页',
      total: 10,
      pageSize: 10,
      items: [{ name: 'Item 1' }, { name: 'Item 2' }, { name: 'Item 3' }]
    }
  },
  methods: {
    onPageChanged (page) {
      console.log('Page changed to: ', page);
      // 当前页面数据请求
    }
  }
}
</script>

Dalam kod di atas, kami telah memperkenalkan komponen Penomboran dan menjadikannya komponen induk dalam templat. Kami juga mengikat jumlah, semasa dan maxShown kepada komponen untuk mendapatkan nilainya. Dalam kaedah onPageChanged, kami boleh mengendalikan peristiwa perubahan halaman dan meminta data yang sepadan berdasarkan nombor halaman semasa.

Atas ialah kandungan terperinci Amalan komponen Vue: pembangunan komponen halaman. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
Frontend Netflix: Contoh dan Aplikasi React (atau Vue)Frontend Netflix: Contoh dan Aplikasi React (atau Vue)Apr 16, 2025 am 12:08 AM

Netflix menggunakan React sebagai kerangka depannya. 1) Model pembangunan komponen React dan ekosistem yang kuat adalah sebab utama mengapa Netflix memilihnya. 2) Melalui komponen, Netflix memisahkan antara muka kompleks ke dalam ketulan yang boleh diurus seperti pemain video, senarai cadangan dan komen pengguna. 3) Kitaran Hayat DOM dan Komponen Maya React mengoptimumkan kecekapan rendering dan pengurusan interaksi pengguna.

Landskap Frontend: Bagaimana Netflix menghampiri pilihannyaLandskap Frontend: Bagaimana Netflix menghampiri pilihannyaApr 15, 2025 am 12:13 AM

Pilihan Netflix dalam teknologi front-end terutamanya memberi tumpuan kepada tiga aspek: pengoptimuman prestasi, skalabilitas dan pengalaman pengguna. 1. Pengoptimuman Prestasi: Netflix memilih React sebagai kerangka utama dan alat yang dibangunkan seperti SpeedCurve dan Boomerang untuk memantau dan mengoptimumkan pengalaman pengguna. 2. Skalabiliti: Mereka mengamalkan seni bina front-end mikro, memisahkan aplikasi ke dalam modul bebas, meningkatkan kecekapan pembangunan dan skalabilitas sistem. 3. Pengalaman Pengguna: Netflix menggunakan perpustakaan komponen bahan-UI untuk terus mengoptimumkan antara muka melalui ujian A/B dan maklum balas pengguna untuk memastikan konsistensi dan estetika.

React vs Vue: Rangka kerja mana yang digunakan oleh Netflix?React vs Vue: Rangka kerja mana yang digunakan oleh Netflix?Apr 14, 2025 am 12:19 AM

NetflixusesAcustomFrameworkcalled "gibbon" Builtonreact, notreactorsvuedirectly.1) TeamExperience: chectionBasedOnfamiliarity.2) ProjectOplePlexity: VueforsImplerProjects, ReactForComplexones.3)

Pilihan Rangka Kerja: Apa yang mendorong keputusan Netflix?Pilihan Rangka Kerja: Apa yang mendorong keputusan Netflix?Apr 13, 2025 am 12:05 AM

Netflix terutamanya menganggap prestasi, skalabiliti, kecekapan pembangunan, ekosistem, hutang teknikal dan kos penyelenggaraan dalam pemilihan rangka kerja. 1. Prestasi dan Skalabiliti: Java dan Springboot dipilih untuk memproses data besar -besaran dan permintaan serentak yang tinggi. 2. Kecekapan Pembangunan dan Ekosistem: Gunakan React untuk meningkatkan kecekapan pembangunan front-end dan menggunakan ekosistemnya yang kaya. 3. Hutang Teknikal dan Penyelenggaraan Kos: Pilih Node.js untuk membina mikroservis untuk mengurangkan kos penyelenggaraan dan hutang teknikal.

React, Vue, dan Masa Depan Frontend NetflixReact, Vue, dan Masa Depan Frontend NetflixApr 12, 2025 am 12:12 AM

Netflix terutamanya menggunakan React sebagai rangka kerja front-end, ditambah dengan VUE untuk fungsi tertentu. 1) Komponen React dan DOM maya meningkatkan prestasi dan kecekapan pembangunan aplikasi Netflix. 2) VUE digunakan dalam alat dalaman dan projek kecil Netflix, dan fleksibiliti dan kemudahan penggunaannya adalah kunci.

Vue.js di frontend: aplikasi dan contoh dunia nyataVue.js di frontend: aplikasi dan contoh dunia nyataApr 11, 2025 am 12:12 AM

Vue.js adalah rangka kerja JavaScript yang progresif yang sesuai untuk membina antara muka pengguna yang kompleks. 1) Konsep terasnya termasuk data responsif, komponen dan DOM maya. 2) Dalam aplikasi praktikal, ia boleh ditunjukkan dengan membina aplikasi todo dan mengintegrasikan vuerouter. 3) Apabila debugging, disyorkan untuk menggunakan Vuedevtools dan Console.log. 4) Pengoptimuman prestasi boleh dicapai melalui V-IF/V-Show, senarai pengoptimuman rendering, pemuatan asynchronous komponen, dll.

Vue.js dan bertindak balas: Memahami perbezaan utamaVue.js dan bertindak balas: Memahami perbezaan utamaApr 10, 2025 am 09:26 AM

Vue.js sesuai untuk projek kecil dan sederhana, sementara React lebih sesuai untuk aplikasi besar dan kompleks. 1. Sistem responsif vue.js secara automatik mengemas kini DOM melalui pengesanan ketergantungan, menjadikannya mudah untuk menguruskan perubahan data. 2. Leact mengamalkan aliran data sehala, dan data mengalir dari komponen induk ke komponen kanak-kanak, menyediakan aliran data yang jelas dan struktur yang mudah dibuang.

Vue.js vs React: Pertimbangan khusus projekVue.js vs React: Pertimbangan khusus projekApr 09, 2025 am 12:01 AM

Vue.js sesuai untuk projek kecil dan sederhana dan lelaran yang cepat, sementara React sesuai untuk aplikasi besar dan kompleks. 1) Vue.js mudah digunakan dan sesuai untuk situasi di mana pasukan tidak mencukupi atau skala projek kecil. 2) React mempunyai ekosistem yang lebih kaya dan sesuai untuk projek dengan prestasi tinggi dan keperluan fungsional yang kompleks.

See all articles

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),