vant 日历组件优化

本文探讨了vant日历组件在设置min-date和max-date时可能导致的性能问题,以及如何通过滚动加载策略来优化。当需要显示大量日期时,设置固定范围会导致页面卡顿。通过监听month-show事件,动态调整min-date和max-date,只加载当前及相邻三年的日期,实现了流畅的滚动加载效果,有效解决了性能瓶颈。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

vant日历组件优化

vant组件现状

  1. min-date 如果不设置默认当前日期
  2. max-date 如果不设置当前日期的六个月后
    目的:这个组件这么设置的目的就是为了节省性能

公司需求

  1. min-data 可无限小 可以选择到1970 年
  2. max-data 可无限大 可以选择很久以后的时间
    问题:如果单纯的设置min-date 为new Date(1970,0,1)、max-date为new Date(2099,11,31) 这样会导致超大量的dom 结构,会导致打开页面非常 的卡顿

为了解决此问题我们可以滚动加载日历,让日历结构保持在3年内

  1. van-calendar 提供month-show api(当某个月份进入可视区域时触发)
    ps:我们可以利用此API做到滚动加载日历
    伪代码
// 获取当前年
  const currentYear = moment().toObject().years
  设置一个 初始化的min-data 和max-date
  const minDate= new Date(currentYear - 1, 0 , 1)
  const maxDate = new Date(currentYear + 1, 11 , 31)
  // 当month-show 执行时
  monthShow (date) {
  const {date, time} = date
   const minCurrentYear = moment(minDate).toObject().years
   const maxCurrentYear = moment(maxDate).toObject().years
  const current. =  moment(date).toObject().years
  if (currentYear === minCurrentYear) {
          this.minDate = new Date(minCurrentYear - 1, 0, 1)
          dom.scrollTop = 6636 // 解决上滑动跨年 否则向上滑动的时候会有出现跨年
   }
    if (currentYear === maxCurrentYear) {
          this.maxDate = new Date(maxCurrentYear + 1,11,31)
    }
}

这样就解决卡顿的问题了~

### 关于小程序 Vant 签到日历功能的实现 在小程序开发领域,Vant 是一款非常流行的轻量级移动端组件库,提供了丰富的 UI 组件支持。通过结合 Vant日历组件与后台数据存储技术(如 Redisson BitSet),可以高效地实现签到日历功能。 #### 技术栈概述 - **前端部分**:使用 Vant 提供的日历组件来构建界面交互逻辑[^1]。 - **后端部分**:采用 Redisson 的 BitSet 数据结构记录用户的签到状态,确保高效的读写性能和低内存占用。 以下是具体的技术细节: --- #### 前端实现要点 ##### 日历组件配置 Vant 的 `Calendar` 组件允许开发者灵活定制样式和行为。例如: - 设置可选日期范围。 - 动态标记已签到的日子。 - 处理用户点击事件以触发签到操作。 代码示例如下: ```javascript <van-calendar :poppable="false" :show-confirm="false" @select="onSelectDate" :marked-date-list="signedDates" /> ``` 在此代码片段中,`signedDates` 表示一个数组,用于保存用户已经完成签到的具体日期列表。 ##### 用户交互处理 当用户选择某一天时,调用服务器接口验证并更新签到状态。如果成功,则刷新页面上的标记信息。 ```javascript methods: { onSelectDate(date) { this.$toast.loading({ message: '正在提交...', forbidClick: true }); // 调用API执行签到动作 api.checkIn(date).then(() => { this.signedDates.push(date); this.$toast.success('签到成功'); }).catch(err => { this.$toast.fail(`签到失败:${err.message}`); }); } } ``` 上述方法展示了如何监听日历的选择事件,并向服务端发送请求完成实际业务流程。 --- #### 后端逻辑说明 Redisson 的 BitSet 可以为每位用户提供独立的一位标志位表示当天是否被签过名。相比传统关系型数据库方案,这种方式显著减少了查询开销以及磁盘空间消耗。 假设我们有一个键名为 `"user_signin_bits:{userId}"` ,那么对于某个特定日子来说只需要对该位置进行 SET 或 GET 操作即可得知该天的状态。 伪代码演示: ```java RLock lock = redissonClient.getLock("lock:" + userId); try { boolean isLocked = lock.tryLock(5, TimeUnit.SECONDS); // 加分布式锁防止并发冲突 if (isLocked){ RBitSet bitSet = redissonClient.getBitSet("user_signin_bits:" + userId); int dayOfYear = LocalDate.now().getDayOfYear(); // 获取当前年的第几天 if (!bitSet.get(dayOfYear)){ bitSet.set(dayOfYear); // 执行签到 return Response.ok(); }else{ throw new RuntimeException("今天已经签过了!"); } } } finally { if(lock.isHeldByCurrentThread()) { lock.unlock(); } } ``` 此段 Java 编写的函数实现了基本的防重复机制并通过加锁保障安全性。 --- ### 总结 综上所述,借助 Vant 和 Redisson 这两个强大的工具集,能够快速搭建起具备良好用户体验的小程序签到系统。不仅简化了前端渲染过程中的复杂度,同时也优化了后端的数据管理效率。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值