基于Vue實現支持按周切換的日歷
更新時間:2020年09月24日 09:24:22 作者:嘉爺
這篇文章主要為大家詳細介紹了基于Vue實現支持按周切換的日歷,根據實際開發(fā)情況按每年、每月、每周進行切換,具有一定的參考價值,感興趣的小伙伴們可以參考一下
基于Vue的日歷小功能,可根據實際開發(fā)情況按每年、每月、每周、進行切換,具體內容如下

<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$vvxyksv9kd`
return `${y}-${m}-$vvxyksv9kd`
},
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個 這里默認顯示一周,如果需要顯示一個月,則第二個循環(huán)為 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創(chuàng)建Calendar日歷效果
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Vue中 v-if 和v-else-if頁面加載出現閃現的問題及解決方法
vue中v-if 和v-else-if在頁面加載的時候,不滿足條件的標簽會加載然后再消失掉,如果要解決這個問題,下面小編給大家?guī)砹藢嵗a,需要的朋友參考下吧2018-10-10
Vue3.0利用vue-grid-layout插件實現拖拽布局
這篇文章主要介紹了Vue3.0利用vue-grid-layout插件實現拖拽布局,工作中難免遇到需要對頁面布局進行拖拽然后改變布局,保存布局,下面文章就圍繞Vue3.0利用vue-grid-layout插件實現拖拽布局的相關資料展開詳細內容,需要的朋友可以參考一下2021-11-11
vue項目element UI input框掃碼槍掃描過快出現數據丟失問題及解決方案
這篇文章主要介紹了vue項目element UI input框掃碼槍掃描過快出現數據丟失問題,輸入框要掉兩個接口,根據第一個驗證接口返回的code,彈不同的框,點擊彈框確認再掉第二個接口,需要的朋友可以參考下2022-12-12
vue項目中銷毀window.addEventListener事件監(jiān)聽解析
這篇文章主要介紹了vue項目中銷毀window.addEventListener事件監(jiān)聽,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07

