基于Vue实现支持按周切换的日历
发布时间 - 2026-01-11 02:41:38 点击率:次基于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
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】
Laravel Octane如何提升性能_使用Laravel Octane加速你的应用
,网页ppt怎么弄成自己的ppt?
Laravel项目怎么部署到Linux_Laravel Nginx配置详解
智能起名网站制作软件有哪些,制作logo的软件?
如何在阿里云域名上完成建站全流程?
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言
Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】
高端企业智能建站程序:SEO优化与响应式模板定制开发
Laravel如何自定义错误页面(404, 500)?(代码示例)
Laravel Docker环境搭建教程_Laravel Sail使用指南
海南网站制作公司有哪些,海口网是哪家的?
如何在宝塔面板中创建新站点?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
如何用美橙互联一键搭建多站合一网站?
b2c电商网站制作流程,b2c水平综合的电商平台?
Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】
Laravel Fortify是什么,和Jetstream有什么关系
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
如何快速生成凡客建站的专业级图册?
Swift开发中switch语句值绑定模式
如何在IIS管理器中快速创建并配置网站?
Python文件异常处理策略_健壮性说明【指导】
Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧
googleplay官方入口在哪里_Google Play官方商店快速入口指南
桂林网站制作公司有哪些,桂林马拉松怎么报名?
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
如何打造高效商业网站?建站目的决定转化率
详解Android中Activity的四大启动模式实验简述
打开php文件提示内存不足_怎么调整php内存限制【解决方案】
Laravel用户密码怎么加密_Laravel Hash门面使用教程
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
Laravel怎么为数据库表字段添加索引以优化查询
Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道
php结合redis实现高并发下的抢购、秒杀功能的实例
Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】
如何用狗爹虚拟主机快速搭建网站?
Laravel如何集成Inertia.js与Vue/React?(安装配置)
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
Laravel怎么生成URL_Laravel路由命名与URL生成函数详解
Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程
微信推文制作网站有哪些,怎么做微信推文,急?
Linux安全能力提升路径_长期防护思维说明【指导】
浅谈Javascript中的Label语句
怎样使用JSON进行数据交换_它有什么限制

