cari
Rumahhujung hadapan webView.jsBagaimana untuk melaksanakan komponen kalendar menggunakan Vue?

Vue ialah rangka kerja bahagian hadapan yang sangat popular Ia menyediakan banyak alatan dan fungsi, seperti pembahagian komponen, pengikatan data, pemprosesan acara, dll., yang boleh membantu pembangun membina aplikasi web yang cekap, fleksibel dan mudah diselenggara. Dalam artikel ini, saya akan memperkenalkan cara melaksanakan komponen kalendar menggunakan Vue.

1. Analisis keperluan

Pertama, kita perlu menganalisis keperluan komponen kalendar ini. Kalendar asas harus mempunyai fungsi berikut:

  • Paparkan halaman kalendar bulan semasa
  • Sokongan beralih ke bulan sebelumnya atau bulan berikutnya
  • Sokongan mengklik pada hari tertentu untuk melompat ke halaman maklumat tertentu; hari itu. Pemisahan komponen maklumat bulan dan butang suis;
Badan Kalendar: Bertanggungjawab untuk memaparkan bahagian utama kalendar, iaitu hari.

3. Penulisan komponen

    Sekarang, kami menulis pelaksanaan khusus setiap komponen.
  • Komponen kepala
  • Tanggungjawab utama komponen kepala adalah untuk memaparkan maklumat bulan semasa dan menyediakan fungsi penukaran bulan. Kami boleh melaksanakan penukaran bulan melalui komponen Pilih Kodnya adalah seperti berikut:
  • <template>
      <div class="header">
        <select v-model="currentMonth" @change="onMonthChange">
          <option v-for="month in months" :value="month.value">{{ month.label }}</option>
        </select>
        <button @click="nextMonth">Next</button>
        <button @click="prevMonth">Prev</button>
      </div>
    </template>
    
    <script>
    export default {
      data() {
        return {
          currentMonth: new Date().getMonth() + 1,
          months: [
            { value: 1, label: 'January' },
            { value: 2, label: 'February' },
            { value: 3, label: 'March' },
            { value: 4, label: 'April' },
            { value: 5, label: 'May' },
            { value: 6, label: 'June' },
            { value: 7, label: 'July' },
            { value: 8, label: 'August' },
            { value: 9, label: 'September' },
            { value: 10, label: 'October' },
            { value: 11, label: 'November' },
            { value: 12, label: 'December' },
          ],
        };
      },
      methods: {
        nextMonth() {
          this.currentMonth++;
          if (this.currentMonth > 12) {
            this.currentMonth = 1;
          }
        },
        prevMonth() {
          this.currentMonth--;
          if (this.currentMonth < 1) {
            this.currentMonth = 12;
          }
        },
        onMonthChange() {
          // 处理月份切换
        },
      },
    };
    </script>
  • Di sini kami melaksanakan penukaran bulan melalui komponen Pilih, dan mengisytiharkan bulan semasa Bulan semasa dan senarai semua bulan dalam komponen. Pada masa yang sama, kami juga menambah kaedah nextMonth dan prevMonth pada komponen untuk melaksanakan fungsi penukaran bulan.

Komponen Utama Kalendar

Tanggungjawab utama komponen utama kalendar adalah untuk memaparkan bahagian utama kalendar, iaitu hari. Untuk mencapai kefungsian ini, kita boleh menggunakan gelung for untuk melelaran sepanjang hari dalam bulan semasa dan menjadikannya. Pada masa yang sama, kita juga perlu mengambil kira bahawa komponen kalendar merangkumi beberapa bulan, jadi kita perlu mengira bilangan hari dalam setiap bulan dan hari dalam minggu yang merupakan hari pertama setiap bulan. Untuk masalah ini, kami boleh menggunakan perpustakaan Moment.js untuk pemprosesan tarikh/masa. Kodnya adalah seperti berikut:

<template>
  <div class="body">
    <div class="day" v-for="day in days" :key="day" :class="{ disabled: day === 0 }" @click="onClick(day)">
      {{ day === 0 ? '' : day }}
    </div>
  </div>
</template>

<script>
import moment from 'moment';

export default {
  props: {
    month: Number,
    year: Number,
  },
  data() {
    return {
      days: [],
    };
  },
  computed: {
    startDay() {
      return moment(`${this.year}-${this.month}-01`).day();
    },
    totalDays() {
      return moment(`${this.year}-${this.month}`, 'YYYY-MM').daysInMonth();
    },
  },
  methods: {
    onClick(day) {
      if (day !== 0) {
        // 跳转到该天的具体信息页面
      }
    },
  },
  mounted() {
    let days = Array.from({ length: 42 }).fill(0);
    for (let i = 1; i <= this.totalDays; i++) {
      days[i + this.startDay - 1] = i;
    }
    this.days = days;
  },
};
</script>

Di sini kami mula-mula memperkenalkan perpustakaan Moment.js dan mentakrifkan dua prop, bulan dan tahun, dalam komponen untuk mewakili bulan dan tahun di mana badan kalendar semasa berada. Kemudian, kami menentukan dua sifat yang dikira: startDay dan totalDays, yang digunakan untuk mengira hari dalam seminggu dan bilangan hari dalam bulan masing-masing apabila hari pertama bulan semasa adalah. Akhir sekali, kami menggunakan fungsi cangkuk yang dipasang untuk memulakan data hari, dan menggunakan gelung for untuk merentasi hari setiap bulan dan menjadikannya pada halaman.

Komponen Kalendar

Akhir sekali, mari tulis keseluruhan komponen kalendar. Tanggungjawab utama komponen kalendar adalah untuk mengintegrasikan dua komponen di atas dan mengendalikan beberapa logik global. Kodnya adalah seperti berikut:

<template>
  <div class="calendar">
    <Header />
    <div class="weekdays">
      <div class="weekday">Sun</div>
      <div class="weekday">Mon</div>
      <div class="weekday">Tue</div>
      <div class="weekday">Wed</div>
      <div class="weekday">Thu</div>
      <div class="weekday">Fri</div>
      <div class="weekday">Sat</div>
    </div>
    <Body :month="currentMonth" :year="currentYear" />
  </div>
</template>

<script>
import Header from './Header.vue';
import Body from './Body.vue';

export default {
  components: {
    Header,
    Body,
  },
  data() {
    return {
      currentMonth: new Date().getMonth() + 1,
      currentYear: new Date().getFullYear(),
    };
  },
};
</script>

Di sini, kami memperkenalkan komponen Pengepala dan Badan dan menyarangkannya dalam bekas. Pada masa yang sama, kami juga mengisytiharkan bulan dan tahun semasa dalam komponen.

4. Gunakan komponen kalendar

Kini, kita boleh menggunakan komponen kalendar kita di mana sahaja kalendar diperlukan. Contohnya:

<template>
  <div>
    <Calendar /> <!-- 展示日历组件 -->
  </div>
</template>

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

export default {
  components: {
    Calendar,
  },
};
</script>

Dengan cara ini, kami telah berjaya melaksanakan komponen kalendar mudah menggunakan Vue. Sudah tentu, ini hanyalah versi asas, dan anda boleh melanjutkan fungsinya atau mencantikkan antara mukanya mengikut keperluan sebenar anda. Semoga artikel ini dapat membantu anda.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan komponen kalendar menggunakan Vue?. 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
Memahami Vue.js: Terutama rangka kerja frontendMemahami Vue.js: Terutama rangka kerja frontendApr 17, 2025 am 12:20 AM

Vue.js adalah kerangka JavaScript yang progresif yang dikeluarkan oleh You Yuxi pada tahun 2014 untuk membina antara muka pengguna. Kelebihan terasnya termasuk: 1. Pengikatan data responsif, Paparan Kemas Kini Automatik Perubahan Data; 2. Pembangunan komponen, UI boleh dibahagikan kepada komponen bebas dan boleh diguna semula.

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.

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)
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi 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),

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 Mac版

Dreamweaver Mac版

Alat pembangunan web visual