vue手写日历

Posted David凉宸

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue手写日历相关的知识,希望对你有一定的参考价值。

<template>
  <div class="page">
    输入月份数字<input v-model="inputVal" type="text"><button @click="change">点击</button>
    <ul class="calendar">
      <li class="header">
        
                new Date().getFullYear() + '年' + (currentMonth+1) + '月'
              
      </li>
      <li class="week">
        <p></p>
        <p></p>
        <p></p>
        <p></p>
        <p></p>
        <p></p>
        <p></p>
      </li>
      <li class="row day">
        <span class="prevDay date" v-for="item in prevDays" :key="'A' + item"> item </span>
        <span v-for="item in currentDays" :key="'B' + item" class="nowDay date"> item </span>
        <span class="nextDay date" v-for="item in nextDays" :key="'A' + item"> item </span>
      </li>
    </ul>
  </div>
</template>

<script>
export default 
  data() 
    return 
      week: ["日", "一", "二", "三", "四", "五", "六"],
      currentDay: new Date().getDate(),
      currentMonth: new Date().getMonth(),
      currentYear: new Date().getFullYear(),
      inputVal: ''
    ;
  ,
  computed: 
    currentMonthChinese() 
      return new Date(this.currentYear, this.currentMonth).toLocaleString(
        'default',
         month: 'short' 
      )
    ,
    currentDays() 
      return new Date(this.currentYear, this.currentMonth + 1, 0).getDate()
    ,
    prevDays() 
      let data = new Date(this.currentYear, this.currentMonth, 0).getDate()
      let num = new Date(this.currentYear, this.currentMonth, 1).getDay()
      var days = []
      while (num > 0) 
        days.push(data--)
        num--
      
      return days.sort()
    ,
    nextDays() 
      const m = this.currentMonth + 1
      let num = new Date(this.currentYear, m, 1).getDay()
      var days = []
      let number = 0
      while (num < 7) 
        number++
        days.push(number)
        num++
      
      return days.sort()
    
  ,
  methods: 
    change()
      this.currentMonth = Number(this.inputVal) -1
    
  ,
;
</script>

<style lang="scss">
.calendar 
  width: 730px;
  .header 
    display: flex;
    align-items: center;
    height: 64px;
    background: #f9f9f9;
    border-radius: 4px 4px 0px 0px;
    border: 2px solid #f4f4f4;
    font-size: 28px;
    font-family: PingFangSC-Semibold, PingFang SC;
    font-weight: 600;
    color: #404040;
    padding-left: 20px;
  
  .week 
    display: flex;
    height: 64px;
    background: #fefefe;
    border: 2px solid #f4f4f4;
    font-size: 24px;
    font-family: PingFangSC-Regular, PingFang SC;
    font-weight: 400;
    color: #404040;
    p 
      width: 100px;
      height: 64px;
    
  
  .row 
    width: 100%;
    display: flex;
    justify-content: space-between;
  
  .day 
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    span 
      width: 100px;
      height: 30px;
      line-height: 30px;
      text-align: center;
    
    .date 
      display: flex;
      align-items: center;
      justify-content: center;
      width: 100px;
      height: 94px;
      background: #fefefe;
      border: 2px solid #f4f4f4;
      font-size: 28px;
      font-family: PingFangSC-Medium, PingFang SC;
      font-weight: 500;
      color: #9b9b9b;
    
    .nowDay 
      background: #404040;
    
  

</style>

以上是关于vue手写日历的主要内容,如果未能解决你的问题,请参考以下文章

vue初学实践之路——vue简单日历组件

Vue.js与WdatePicker日历控件冲突问题的解决方案

vue.js 使用计时器自动重新加载/刷新数据

vue手写日历

VUE版手写日历组件

2021年,让我们手写一个mini版本的vue2.x和vue3.x框架