广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue版日历组件的实现方法
  • 613
分享到

vue版日历组件的实现方法

2024-04-02 19:04:59 613人浏览 泡泡鱼
摘要

开发背景 常用日历组件可能满足不了我们自定义的多种需求(比如样式),因此通常情况下我们可能需要自己手动开发款日历,先上图 开发流程 1. 根据常用日历样式,我们template部分

开发背景

常用日历组件可能满足不了我们自定义的多种需求(比如样式),因此通常情况下我们可能需要自己手动开发款日历,先上图

开发流程

1. 根据常用日历样式,我们template部分可以分为三部分(上下月及当前月份展示;周日至周六展示;主体日期展示三部分)

1) template部分代码

<div class="date">
    <div class="header">
        <span class="pre_month" @click="onPreMonth"></span>
        <span v-cloak>{{ date.year }}年{{ date.month }}月</span>
        <span class="next_month" @click="onNextMonth"></span>
    </div>
    <div class="days">
        <table v-cloak border="0" cellspacing="0" cellpadding="0">
            <tr class="label">
                <td>周日</td>
                <td>周一</td>
                <td>周二</td>
                <td>周三</td>
                <td>周四</td>
                <td>周五</td>
                <td>周六</td>
            </tr>
            <tr class="row" v-for="week in weeks" :key="week[0].date">
                <td
                    class="column"
                    v-for="day in week"
                    :key="day.date"
                    v-bind:day="day.date"
                    @click="onSelectDay(day)"
                >
            <span
                v-bind:class="[{
                   checked: selectedDate == day.date,
                   weekend: day.isWeekend,
                 }]"
                    v-if="day.month == date.month">{{ day.v }}</span>
                </td>
            </tr>
        </table>
    </div>
</div>

2)js部分代码

// 生成日历函数
initDate(month) {
    var weeks = [] // template中用来渲染日历的数组
    var firstDay = this.moment(month, 'YYYY-MM') // 当月1号
    var week = firstDay.fORMat('d') // 当月1号是周几 (比如周五则week = 5)
    var start = firstDay.subtract(week, 'days') // 日历上展示的第一个数(上个月的二十几号之类的,用于补齐日历)
    for (var i = 0; i < 6; i++) { // 通常日历为6行7排 42天,因此两个for循环
        var days = []
        for (var j = 0; j < 7; j++) {
            var day = {}
            day.num = start.toObject().date // 当前号数 22
            day.date = start.format('YYYY-MM-DD') // 返回值为2021-10-22
            day.month = start.format('MM') // 当前号数对应的月份,比如日历上个月27号则day.month = 9;这个月1号day.month = 10
            day.isWeekend = (start.format('E') === '6' || start.format('E') === '7') ? true : false // 是否是周末,用于UI区分周末和平时的颜色
            start.add(1, 'days')  // 没循环一次日期加一天
            days.push(day)
        }
        weeks.push(days)
    }
    this.date.year = this.moment(month).year()
    this.date.month = this.moment(month, 'YYYY-MM').add(0, 'month').format('MM')
    this.date.preMonth = this.moment(month, 'YYYY-MM').add(-1, 'month').format('YYYY-MM')
    this.date.nextMonth = this.moment(month, 'YYYY-MM').add(1, 'month').format('YYYY-MM')
    return weeks
}

初始化完成后调用(用于template中渲染)

mounted() {
    const currDate = new Date()
    this.weeks = this.initDate(this.moment(currDate).format('YYYY-MM'))
}

上个月、下个月处理

// 上一个月
onPreMonth() {
    const month = this.date.preMonth
    this.weeks = this.getCalendar(this.moment(month).format('YYYY-MM'))
},

// 下一个月
onNextMonth() {
    const month = this.date.nextMonth
    this.weeks = this.getCalendar(this.moment(month).format('YYYY-MM'))
}

选中某一天

onSelectDay(day) {
    if (!this.isSelectDay) return false
    if (day.month === this.date.month) {
        this.selectedDate = day.date
    }
}

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

--结束END--

本文标题: vue版日历组件的实现方法

本文链接: https://www.lsjlt.com/news/146315.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue版日历组件的实现方法
    开发背景 常用日历组件可能满足不了我们自定义的多种需求(比如样式),因此通常情况下我们可能需要自己手动开发款日历,先上图 开发流程 1. 根据常用日历样式,我们template部分...
    99+
    2022-11-13
  • vue实现日历组件
    基于VUE实现日历组件,供大家参考,具体内容如下 年和月份是使用输入框来切换的,没有做成选择框,⬅️和➡️切换月份,红色选取是选取的日期实现思路和网上的大多数一样,首先是把月份的天...
    99+
    2022-11-13
  • vue日历组件的封装方法
    本文实例为大家分享了vue日历组件的封装代码,供大家参考,具体内容如下 图示 封装的组件的代码如下 <template>   <div class="calend...
    99+
    2022-11-13
  • 如何实现vue日历组件
    这篇文章主要介绍了如何实现vue日历组件,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1. 前言最近做项目遇到一个需求,需要制作一个定制化的日历组件(项目使用的UI框架不能满...
    99+
    2023-06-29
  • vue的h5日历组件实现详解
    本文实例为大家分享了vue的h5日历组件实现代码,供大家参考,具体内容如下 日历样式自定义 日历组件 <template>   <section class="...
    99+
    2022-11-13
  • vue实现垂直无限滑动日历组件
    用vue做了一个垂直无限滑动日历,在这里记录一下实现。 效果 组件 verticalCalendar.vue <template>   <div ref="con...
    99+
    2022-11-13
  • Flutter 日历组件简单实现
    目录前言安装效果demo 演示业务使用 headerView使用配置属性DEMO感谢前言 近期有个业务需求,涉及用户付费相关的计算,需要一个日历组件,组件功能如下: 仅支持从明天开始...
    99+
    2022-11-13
    Flutter 日历组件 Flutter 日历
  • vue怎么实现垂直无限滑动日历组件
    这篇文章主要介绍“vue怎么实现垂直无限滑动日历组件”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue怎么实现垂直无限滑动日历组件”文章能帮助大家解决问题。效果组件verticalCalendar...
    99+
    2023-06-30
  • vue.js实现日历插件使用方法详解
    今天要实现的功能就是以下这个功能:vue.js模拟日历插件 好了废话不多说了 直接上代码了 css: *{ margin: 0; padding: 0;...
    99+
    2022-11-12
  • 基于vue2实现一个日历组件
    目录QCalendar.scssgetRangeDay.jsformatTime.jsQCalendar.vue日历组件效果图日月年tips总结不用任何第三方库,只基于vue2实现一...
    99+
    2022-12-29
    vue日历组件 切换月周日都可选择 vue 日历 Vue 日程日历
  • Android使用GridView实现日历的方法
    在开发中可能会遇到某些情况下需要用到日历的功能,并且还要在日历上加标签什么的,最重要的就是android自带的日历由于各个系统版本不同导致日历的样式也不同,这样就会导致使用起来比较麻烦..而且在日历中加标签也不好实现...所以很多时候日历都...
    99+
    2023-05-30
    android 日历 gridview
  • Vue弹窗组件的实现方法
    本文实例为大家分享了Vue弹窗组件的实现具体代码,供大家参考,具体内容如下 弹窗组件包含内容: 弹窗遮罩层内容层的实现(涉及slot、props、$on、$emit) 实现步骤: 1...
    99+
    2022-11-13
  • vue自定义可选时间的日历组件
    本文实例为大家分享了vue自定义可选时间日历组件的具体代码,供大家参考,具体内容如下 日历功能: 1、过去时间不可选择 2、可自定义不可选时间 3、本月默认展示当天,其他月展示第一天...
    99+
    2022-11-12
  • 基于Vue3实现日历组件的示例代码
    以下是一个基于 Vue 3 实现的简单日历组件的代码示例。这个日历组件包含了前一个月、当前月、下一个月的日期,并且可以支持选择日期、切换月份等功能。 <template>...
    99+
    2023-05-17
    Vue3实现日历组件 Vue3日历组件 Vue3日历 Vue 日历
  • vue选项卡组件的实现方法
    本文实例为大家分享了vue选项卡组件的实现代码,供大家参考,具体内容如下 主要功能:点击不同的选项,显示不同的内容 html <!DOCTYPE html> <ht...
    99+
    2022-11-13
  • Vue实现可拖拽组件的方法
    本文为大家分享了Vue实现可拖拽、拖拽组件,供大家参考,具体内容如下 描述: 组件仅封装拖拽功能,内容通过#header、#default、#footer插槽 自定义 效果:&nbs...
    99+
    2022-11-12
  • vue实现钉钉的考勤日历
    本文实例为大家分享了vue实现钉钉的考勤日历的具体代码,供大家参考,具体内容如下 直接上效果图,需要再往下看 GitHub地址:vue-calendar-component 由于需...
    99+
    2022-11-12
  • vue中使用element日历组件的示例代码
    先看下效果图: 完整代码附上 <template> <div class="newSeeds" id="famerCalendar"> ...
    99+
    2022-11-12
  • 基于element日历组件实现签卡记录
    本文实例为大家分享了基于element日历组件实现签卡记录的具体代码,供大家参考,具体内容如下 使用element日历组件为基础,实现可以查看每天签卡记录 <template&...
    99+
    2022-11-13
  • vue3.0实现考勤日历组件使用详解
    本文实例为大家分享了vue3.0实现考勤日历组件使用的具体代码,供大家参考,具体内容如下 自定义日历组件,首先我们要明确需求与面板展示内容 1、周日~周六。2、当前月日历1~(28...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作