全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

基于Vue实现支持按周切换的日历

基于Vue的日历小功能,可根据实际开发情况按每年、每月、每周、进行切换,具体内容如下

<template>
 <div class="date">
  <!-- 年份 月份 -->
  <div class="month">
  <p>{{ currentYear }}年{{ currentMonth }}月</p>
  </div>
  <!-- 星期 -->
  <ul class="weekdays">
  <li>一</li>
  <li>二</li>
  <li>三</li>
  <li>四</li>
  <li>五</li>
  <li>六</li>
  <li>日</li>
  </ul>
  <!-- 日期 -->
  <ul class="days">
  <li @click="pick(day)" v-for="(day, index) in days" :key="index">
   <!--本月-->
   <span v-if="day.getMonth()+1 != currentMonth" class="other-month">{{ day.getDate() }}</span>
   <span v-else>
   <!--今天-->
   <span v-if="day.getFullYear() == new Date().getFullYear() && day.getMonth() == new Date().getMonth() && day.getDate() == new Date().getDate()" class="active">{{ day.getDate() }}</span>
   <span v-else>{{ day.getDate() }}</span>
   </span>
  </li>
  </ul>
 </div>
</template>

js部分:目前默认显示一周,可根据实际情况更改

<script>


 export default {
 name: 'date',

 data () {
  return {
  currentYear: 1970, // 年份
  currentMonth: 1, // 月份
  currentDay: 1, // 日期
  currentWeek: 1, // 星期
  days: [],
  }
 },

 mounted () {

 },

 created () {
  this.initData(null)
 },

 methods: {
  formatDate (year, month, day) {
  const y = year
  let m = month
  if (m < 10) m = `0${m}`
  let d = day
  if (d < 10) d = `0${d}`
  return `${y}-${m}-${d}`
  },

  initData (cur) {
  let date = ''
  if (cur) {
   date = new Date(cur)
  } else {
   date = new Date()
  }
  this.currentDay = date.getDate()   // 今日日期 几号
  this.currentYear = date.getFullYear()  // 当前年份
  this.currentMonth = date.getMonth() + 1 // 当前月份
  this.currentWeek = date.getDay() // 1...6,0 // 星期几
  if (this.currentWeek === 0) {
   this.currentWeek = 7
  }
  const str = this.formatDate(this.currentYear, this.currentMonth, this.currentDay)// 今日日期 年-月-日
  this.days.length = 0
  // 今天是周日,放在第一行第7个位置,前面6个 这里默认显示一周,如果需要显示一个月,则第二个循环为 i<= 35- this.currentWeek
  /* eslint-disabled */
  for (let i = this.currentWeek - 1; i >= 0; i -= 1) {
   const d = new Date(str)
   d.setDate(d.getDate() - i)
   // console.log(y:" + d.getDate())
   this.days.push(d)
  }
  for (let i = 1; i <= 7 - this.currentWeek; i += 1) {
   const d = new Date(str)
   d.setDate(d.getDate() + i)
   this.days.push(d)
  }
  },

  // 上个星期
  weekPre () {
  const d = this.days[0] // 如果当期日期是7号或者小于7号
  d.setDate(d.getDate() - 7)
  this.initData(d)
  },

  // 下个星期
  weekNext () {
  const d = this.days[6] // 如果当期日期是7号或者小于7号
  d.setDate(d.getDate() + 7)
  this.initData(d)
  },

  // 上一個月 传入当前年份和月份
  pickPre (year, month) {
  const d = new Date(this.formatDate(year, month, 1))
  d.setDate(0)
  this.initData(this.formatDate(d.getFullYear(), d.getMonth() + 1, 1))
  },


  // 下一個月 传入当前年份和月份
  pickNext (year, month) {
  const d = new Date(this.formatDate(year, month, 1))
  d.setDate(35)
  this.initData(this.formatDate(d.getFullYear(), d.getMonth() + 1, 1))
  },

  // 当前选择日期
  pick (date) {
  alert(this.formatDate(date.getFullYear(), date.getMonth() + 1, date.getDate()))
  },
 },
 }
</script>
<style lang="scss">
 @import "~base";

 .date {
 height: px2rem(180);
 color: #333;

 .month {
  font-size: px2rem(24);
  text-align: center;
  margin-top: px2rem(20);
 }

 .weekdays {
  display: flex;
  font-size: px2rem(28);
  margin-top: px2rem(20);

  li {
  flex: 1;
  text-align: center;
  }
 }

 .days {
  display: flex;

  li {
  flex: 1;
  font-size: px2rem(30);
  text-align: center;
  margin-top: px2rem(10);
  line-height: px2rem(60);

  .active {
   display: inline-block;
   width: px2rem(60);
   height: px2rem(60);
   color: #fff;
   border-radius: 50%;
   background-color: #fa6854;
  }

  .other-month {
   color: #e4393c;
  }
  }
 }
 }
</style>

相关参考链接:Vue.js创建Calendar日历效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Vue  # 日历  # VUE实现日历组件功能  # vue实现一个炫酷的日历组件  # Vue.js创建Calendar日历效果  # 基于Vue2-Calendar改进的日历组件(含中文使用说明)  # vue实现简单的日历效果  # Vue实现日历小插件  # Vue编写可显示周和月模式的日历 Vue自定义日历内容的显示  # vue+elementUI实现简单日历功能  # vue实现日历备忘录功能  # 使用Vue实现简单日历效果  # 可根据  # 今日  # 放在  # 一个月  # 上一  # 下一  # 第二个  # 实际情况  # 上个  # 下个  # 具体内容  # 大家多多  # 周日  # 按每  # 几号  # Date  # getFullYear  # getDate  # js  # active 


相关文章: Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  深圳 网站制作,深圳招聘网站哪个比较好一点啊?  网站制作软件有哪些,制图软件有哪些?  ,怎么用自己头像做动态表情包?  香港服务器租用费用高吗?如何避免常见误区?  盘锦网站制作公司,盘锦大洼有多少5G网站?  如何获取上海专业网站定制建站电话?  制作表格网站有哪些,线上表格怎么弄?  如何用wdcp快速搭建高效网站?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  大学网站设计制作软件有哪些,如何将网站制作成自己app?  宝塔建站教程:一键部署配置流程与SEO优化实战指南  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  如何在自有机房高效搭建专业网站?  头像制作网站在线制作软件,dw网页背景图像怎么设置?  全景视频制作网站有哪些,全景图怎么做成网页?  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  ,制作一个手机app网站要多少钱?  台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?  如何续费美橙建站之星域名及服务?  手机网站制作与建设方案,手机网站如何建设?  如何在阿里云虚拟服务器快速搭建网站?  如何通过cPanel快速搭建网站?  如何在Windows服务器上快速搭建网站?  潍坊网站制作公司有哪些,潍坊哪家招聘网站好?  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  如何选择适配移动端的WAP自助建站平台?  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  如何打造高效商业网站?建站目的决定转化率  佛山网站制作系统,佛山企业变更地址网上办理步骤?  佛山企业网站制作公司有哪些,沟通100网上服务官网?  如何配置WinSCP新建站点的密钥验证步骤?  建站168自助建站系统:快速模板定制与SEO优化指南  如何用景安虚拟主机手机版绑定域名建站?  建站之星如何助力企业快速打造五合一网站?  如何在万网主机上快速搭建网站?  高端智能建站公司优选:品牌定制与SEO优化一站式服务  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  制作网站的软件免费下载,免费制作app哪个平台好?  建站之星好吗?新手能否轻松上手建站?  b2c电商网站制作流程,b2c水平综合的电商平台?  建站之星如何开启自定义404页面避免用户流失?  深圳网站制作培训,深圳哪些招聘网站比较好?  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  Python路径拼接规范_跨平台处理说明【指导】  C++如何使用std::optional?(处理可选值)  如何在企业微信快速生成手机电脑官网?  东莞专业制作网站的公司,东莞大学生网的网址是什么?  如何批量查询域名的建站时间记录? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。