Maison > interface Web > Voir.js > le corps du texte

Comment implémenter la fonction de calendrier dans Vue

WBOY
Libérer: 2023-11-07 15:57:31
original
1050 Les gens l'ont consulté

Comment implémenter la fonction de calendrier dans Vue

Comment implémenter la fonction de calendrier dans Vue

Avec la popularité des applications Web, la fonction de calendrier est devenue une exigence courante pour de nombreux sites Web et applications. Il n'est pas difficile d'implémenter la fonction de calendrier dans Vue. Le processus d'implémentation sera présenté en détail ci-dessous et des exemples de code spécifiques seront fournis.

Tout d'abord, nous devons créer un composant Vue pour héberger la fonction de calendrier. On peut nommer ce composant « Calendrier ». Dans ce composant, nous devons définir certaines données et méthodes pour contrôler l'affichage et l'interaction du calendrier.

<template>
  <div class="calendar">
    <div class="header">
      <button @click="prevMonth">&larr;</button>
      <h2>{{ currentMonth }}</h2>
      <button @click="nextMonth">&rarr;</button>
    </div>
    <div class="days">
      <div v-for="day in days" :key="day">{{ day }}</div>
    </div>
    <div class="dates">
      <div v-for="date in visibleDates" :key="date">{{ date }}</div>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      currentMonth: '',
      days: [],
      visibleDates: []
    };
  },
  mounted() {
    this.initCalendar();
  },
  methods: {
    initCalendar() {
      const now = new Date();
      const year = now.getFullYear();
      const month = now.getMonth();
      this.currentMonth = `${year}-${month + 1}`;

      const firstDay = new Date(year, month, 1).getDay();
      const lastDay = new Date(year, month + 1, 0).getDate();

      this.days = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'];
      this.visibleDates = Array(firstDay).fill('').concat(Array.from({ length: lastDay }, (_, i) => i + 1));
    },
    prevMonth() {
      const [year, month] = this.currentMonth.split('-').map(Number);
      const prevMonth = month === 1 ? 12 : month - 1;
      const prevYear = month === 1 ? year - 1 : year;

      this.currentMonth = `${prevYear}-${prevMonth}`;
      this.updateVisibleDates();
    },
    nextMonth() {
      const [year, month] = this.currentMonth.split('-').map(Number);
      const nextMonth = month === 12 ? 1 : month + 1;
      const nextYear = month === 12 ? year + 1 : year;

      this.currentMonth = `${nextYear}-${nextMonth}`;
      this.updateVisibleDates();
    },
    updateVisibleDates() {
      const [year, month] = this.currentMonth.split('-').map(Number);
      const firstDay = new Date(year, month - 1, 1).getDay();
      const lastDay = new Date(year, month, 0).getDate();

      this.visibleDates = Array(firstDay).fill('').concat(Array.from({ length: lastDay }, (_, i) => i + 1));
    }
  }
};
</script>

<style scoped>
.calendar {
  width: 400px;
  margin: 0 auto;
}

.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}

.dates {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
</style>
Copier après la connexion

Le code ci-dessus implémente un composant de calendrier de base. Nous définissons les données du mois en cours, du jour de la semaine et des dates visibles dans data, utilisons la fonction hook montée pour initialiser le calendrier, et utilisons prevMonth et la méthode nextMonth pour changer de mois, utilisez la méthode updateVisibleDates pour mettre à jour les dates visibles. data中定义了当前月份、星期几和可见日期的数据,使用mounted钩子函数来初始化日历,使用prevMonthnextMonth方法来切换月份,使用updateVisibleDates方法来更新可见日期。

在模板中,我们使用v-for指令来循环渲染星期几和日期,并用@click指令绑定事件来实现点击切换月份。

在样式中,我们使用了grid

Dans le modèle, nous utilisons la directive v-for pour afficher cycliquement les jours de la semaine et les dates, et utilisons la directive @click pour lier les événements pour changer de mois. en cliquant.

Dans le style, nous utilisons la disposition grille pour afficher la grille des jours de la semaine et des dates.

En utilisant ce composant de calendrier dans le composant parent, vous pouvez implémenter la fonctionnalité de calendrier dans votre application Vue.

Résumé : 🎜🎜En utilisant les instructions de liaison de données, de liaison d'événements et de boucle de Vue, nous pouvons facilement implémenter la fonction de calendrier. Le code ci-dessus fournit uniquement un composant de calendrier de base que vous pouvez étendre et personnaliser en fonction de vos besoins. J'espère que cet article vous aidera ! 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!