vue简单的日历

<ul class="date">
<li v-for="(item, index) in list" :key="index" :class="{'bg-color': item.y === year && item.m === month && item.d === day}">
<div class="day" :class="{'text-color': item.cur}">{{item.d}}</div>
<div>哈哈</div>
</li>
</ul>
data () {
  return {
    year: new Date().getFullYear(), // 今日年份
    month: new Date().getMonth() + 1, // 今日月份
    day: new Date().getDate(), // 今日日份
    currentYear: '', // 当前显示年份
    currentMonth: '', // 当前显示月份 0-11,显示时加一
    currentDay: '', // 当前显示日份
    monthDays: [], // 1-12月的天数
    list: []
  }
},
mounted () {
  this.showCalender()
},
methods: {
  isLeap (year) { // 判断是不是闰年
    return (year % 100 === 0 ? (year % 400 === 0 ? 1 : 0) : (year % 4 === 0 ? 1 : 0))
  },
  showCalender (type) {
    this.list = []
    this.newDate = new Date()
    if (!type) this.currentYear = this.newDate.getFullYear()
    if (!type) this.currentMonth = this.newDate.getMonth()
    this.monthDays = [31, 28 + this.isLeap(this.currentYear), 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
    this.currentDay = this.newDate.getDate()
    this.firstDay = new Date(`${this.currentYear}-${this.currentMonth + 1}-1`)
    this.firstnow = this.firstDay.getDay() // 当月第一日是星期几 1-7
    if (this.firstnow === 0) this.firstnow = 7
    if (this.firstnow > 1) {
      // 前一个月份
      let monIndex = this.currentMonth
      let year
      if (monIndex === 0) {
        year--
        monIndex = 11
      } else {
        monIndex--
      }
      for (let i = 0; i < this.firstnow - 1; i++) {
        this.list.unshift({
          y: year,
          m: monIndex + 1,
          d: this.monthDays[monIndex] - i
        })
      }
    }
    for (let i = 0; i < this.monthDays[this.currentMonth]; i++) {
      // 当前月份
      this.list.push({
        y: this.currentYear,
        m: this.currentMonth + 1,
        d: i + 1,
        cur: true
      })
    }
    const num = (this.monthDays[this.currentMonth] + this.firstnow - 1) % 7
    if (num > 0) {
      // 下个月份
      let monIndex2 = this.currentMonth
      let year2
      if (monIndex2 === 11) {
        year2++
        monIndex2 = 0
      } else {
        monIndex2++
      }
      for (let i = 0; i < 7 - num; i++) {
        this.list.push({
          y: year2,
          m: monIndex2 + 1,
          d: i + 1
        })
      }
    }
  },
  preMon () {
    if (this.currentMonth === 0) {
      this.currentYear--
      this.currentMonth = 11
    } else {
      this.currentMonth--
    }
    this.showCalender('pre')
  },
  nextMon () {
    if (this.currentMonth === 11) {
      this.currentYear++
      this.currentMonth = 0
    } else {
      this.currentMonth++
    }
    this.showCalender('next')
  }
// scss 只放了表格样式
ul{
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  align-items: center;
  border-top: 1rpx solid #E9E9E9;
  border-left: 1rpx solid #E9E9E9;
  li{
    flex-grow: 1;
    min-width: 44px;
    height: 50px;
    border-bottom: 1rpx solid #E9E9E9;
    border-right: 1rpx solid #E9E9E9;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    color: #999;
    font-size: 12px;
    .day{
      margin-bottom: 6px;
    }
    .text-color{
      color: #222;
    }
    &.bg-color{
      background-color: #E9E9E9;
    }
  }
}
vue简单的日历的更多相关文章
- vue初学实践之路——vue简单日历组件(1)
		---恢复内容开始--- 最近做的项目有一个需求,需要有一个日历组件供预定功能使用,之前的代码过于繁琐复杂,所以我采用vue重写了这个组件. npm.vue等等安装. 只是一个简单的日历组件,所以并不 ... 
- 【UI插件】简单的日历插件(下)—— 学习MVC思想
		前言 我们上次写了一个简单的日历插件,但是只是一个半成品,而且做完后发现一些问题,于是我们今天尝试来解决这些问题 PS:距离上次貌似很久了 上次,我们大概遇到哪些问题呢: ① 既然想做一套UI库,那么 ... 
- 使用JAVA写一个简单的日历
		JAVA写一个简单的日历import java.text.DateFormat;import java.text.ParseException;import java.text.SimpleDateF ... 
- Vue简单基础 + 实例 及 组件通信
		vue的双向绑定原理:Object.defineProperty() vue实现数据双向绑定主要是:采用数据劫持结合发布者-订阅者模式的方式,通过 Object.defineProperty() 来劫 ... 
- vue简单实现
		vue简单实现 vue的三个核心 虚拟dom, 双向绑定 Proxy, 
- html vue简单
		1.Vue 简单的替换更新 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ... 
- 基于java实现的简单网页日历功能,有兴趣得可以把它转换到前端实现
		之前做项目的时候,因为要用到不同日期显示不同的内容,就自己做了一个日期的显示和选择功能,今天抽空把以前的代码理了一下,顺便就把之前做的日期功能给拿出来回顾一下,大家可以提点意见,帮忙完善下设计.先上一 ... 
- 一篇文章带你了解网页框架——Vue简单入门
		一篇文章带你了解网页框架--Vue简单入门 这篇文章将会介绍我们前端入门级别的框架--Vue的简单使用 如果你以后想从事后端程序员,又想要稍微了解前端框架知识,那么这篇文章或许可以给你带来帮助 温馨提 ... 
- vue初学实践之路——vue简单日历组件(3)
		这一篇我们来实现管理员修改每一天剩余数量的功能. <div id="calendar"> <div id="left"> <spa ... 
随机推荐
- postgres 11 单实例最大支持多少个database?
			有人在pg8时代(10年前)问过,当时说10000个没问题,而且每个db会在/base下建立1个文件夹, 文件ext3只支持32000个子文件夹,所以这是上限了. 而现在早就ext4了,根本没有限制了 ... 
- NGUI实现滑动屏幕的时候,进行环形旋转
			在滑动屏幕的时候,上图中的内容饶圆中心旋转,并且箭头的方向保持不变 每个Item上挂载的脚本: using UnityEngine; public class ItemTest : MonoBehav ... 
- python基础知识点(unittest)
			目录: unittest 单元测试框架 1.写用例: Testcase 2.执行:TestSuite 类 TestLoader 类 3.比对结果(期望值/实际值):断言函数 4.结果:TestText ... 
- Python中怎么读写文件
			python中对文件的操作大概分为三步:打开文件.操作文件(读.写.追加写入).关闭文件. 1.无论对文件做哪种操作,操作前首先要保证文件被打开了,即需要一个打开的操作. 例:open(XXX.txt ... 
- CHM文件命令转换成html
			在Windows下chm转换为html的超简单方法(反编译CHM文件的方法) 通过调用Windows命令,将chm 文件转换为html 文件. 方法: 命令行(cmd),输入hh -decompile ... 
- Mysql报错[Warning] TIMESTAMP with implicit DEFAULT value is deprecated和Buffered warning: Changed limits
			报错2019-04-24 12:06:46 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use -- ... 
- XV Open Cup named after E.V. Pankratiev. GP of Siberia-Swimming
			给出两个点,找到过这两个点的等角螺线,并求出中间的螺线长 $c = \frac{b}{a}$ $p = a \times c^{\frac{\theta}{angle}}$ 对弧线积分 #includ ... 
- 关于node
			nodejs npm常用命令 npm是一个node包管理和分发工具,已经成为了非官方的发布node模块(包)的标准.有了npm,可以很快的找到特定服务要使用的包,进行下载.安装以及管理已经安装的包. ... 
- 学号 2018-2019-20175212 实验一 《Java开发环境的熟悉》
			学号 2018-2019-20175212 实验一 <Java开发环境的熟悉> 一.实验内容及步骤 1.使用JDK编译.运行简单的Java程序 mkdir 20175212exp1创建20 ... 
- 20175212 《Java程序设计》第2周学习总结
			学号 20175212 <Java程序设计>第2周学习总结 教材学习内容总结 1.数据类型 此节介绍的数据类型与C中常用的相比仅多了Boolean(逻辑类型).byte(取值范围:[-12 ... 
