vue-day-calendar 上线啦 🥳🥳

简介

提到日期选择器,大家可能会想到组件库的DatePicker,然而DatePicker通常是Input+Calendar的组合,虽然这适合大多数表单场景,但如果只想展示一个Calendar呢?

vue-day-calendar就是为了解决这个问题而生的。具体可查看文档

ps: 如果说这个组件vue的社区上早就实现了,那就当造个轮子吧 🤣🤣

✨ 特性

  • 国际化多语言
  • 高度可定制化样式,支持 tailwindcsssunocss
  • 使用 dayjs 作为日期库
  • 以选择日期为主的日历组件

VS Vue datepicker

vue-day-calendar之前,我使用过vue-datepicker,它是一个非常优秀的组件库,集成了很多开箱即用的功能,并且它也支持显示Calendar模式,不过如果只用Calendar模式我觉得它太过庞大并且不够纯粹,自由度不高,正应如此,vue-day-calendar诞生了,保持了Calendar的纯粹、无污染的组件。

其实这里还是推荐你们去用vue-datepicker,相对而言,它更加全面,功能更加丰富,懒人首选。

VS React DayPicker

React有着丰富的组件生态,vue-day-calendar的灵感则来源于React DayPicker,有着简约耐看的设计外观且样式高度可定制化,里面的每个组件都可以实现定制化,这对于使用者来说可玩性很高,正因如此,vue-day-calendar借鉴了很多想法。

快速上手

安装

shel 复制代码
pnpm add vue-day-calendar dayjs

用法

html 复制代码
<script setup lang="ts">
  import 'vue-day-calendar/style.css'
  import VueDayCalendar from 'vue-day-calendar'
</script>

<template>
  <VueDayCalendar class="w-250px"/>
</template>

之后你就能得到这样一个效果:

为什么上面需要加宽度呢,因为组件默认是flex布局的,宽度默认跟父节点一样。如果说你想要效果跟最上面的简介图一样,你需要这样写

html 复制代码
<script setup lang="ts">
  import dayjs from 'dayjs'

  import 'vue-day-calendar/style.css'
  import VueDayCalendar from 'vue-day-calendar'

  const yearAndMonthDate = dayjs().format('YYYY-MM')
  const selected = ref(`${yearAndMonthDate}-24`)

  const vueDayCalendarRef = ref<InstanceType<typeof VueDayCalendar>>()

  function goToToday() {
    vueDayCalendarRef.value?.goToToday()
  }
</script>

<template>
  <VueDayCalendar ref="vueDayCalendarRef" v-model="selected">
    <template #footer>
      <div class="w-230px">
        <p class="my-2">
          You picked {{ selected }}
        </p>
        <button 
          class="bg-gray-100 hover:bg-gray-200 px-2.5 py-1 rounded-md" 
          @click="goToToday"
        >
          Go to Today
        </button>
      </div>
    </template>
  </VueDayCalendar>
</template>

这样就能得到这样的效果:

基本用法就介绍到这里了,具体可以去看看文档噢,文档也是很用心写的,如果觉得哪里不好,你也可以来贡献你的想法😆😆,这样vue社区才会越来越好。

写在最后

如果你们喜欢这个组件,欢迎给我点个star,这是对我最大的鼓励。

如果你们使用上遇到疑问,欢迎给我提Issue,我会尽快回复。

如果你们有更好的想法或者觉得文档写的不清晰,欢迎给我提PR,我会尽快合并。

相关推荐
道清茗15 分钟前
【shell编程知识点汇总】第九章 HTML 清洗、多行合并与条件替换
前端·html
噢,我明白了1 小时前
表单的完整 CRUD 练习【极简个人记账本】(含前端后端链接mySQL)
java·前端·数据库·mysql
幽络源小助理1 小时前
MacCMSPro版视频影视系统源码_全开源高可用视频平台解决方案
前端·php·php源码
不会敲代码18 小时前
手写 Zustand:三十分钟带你搞懂状态管理库的核心原理
前端·javascript·源码
神奇的程序员8 小时前
重构了自己5年前写的截图插件
前端·javascript·架构
UXbot9 小时前
一人独立交付 UI + 前端:AI 驱动 UI 设计工具的五大功能模块深度评测
前端·低代码·ui·设计模式·交互
kobesdu9 小时前
【ROS2实战笔记-19】ROS2 生命周期节点的启动顺序、状态转换陷阱与热备方案
java·前端·笔记·机器人·ros·ros2
诚实可靠王大锤9 小时前
React Native 输入框与按钮焦点冲突解决方案(rn版本0.70.3)
前端·javascript·react native·react.js
kyriewen10 小时前
测试妹子让我写单测,我偷偷用AI一天干完一周的活
前端·chatgpt·cursor
2601_9577808410 小时前
Claude Code 2026年最新部署指南:从环境搭建到技能扩展
前端·人工智能·ai编程·claude