【经验分享】如何实现小程序日历范围选择功能

简介: 【经验分享】如何实现小程序日历范围选择功能

前言

小程序里有需要使用到日历选择功能,由于官方没有对应的日历组件,所以我们最开始使用Picker实现了日期范围选择、限制的功能,但是由于UI达不到设计同学的要求,所以没办法,只能手动实现了。

效果图

接入方式

参考下市面上移动端的日历 UI样式及交互习惯,然后我们实现了这样的日历组件,功能单一,没有复杂交互,符合操作习惯。

首先页面JSON引入组件:

{
  "defaultTitle": "日历范围选择器",
  "usingComponents": {
    "calendar": "/components/calendar/index"
  }
}

然后页面axml使用组件:

<button size="default" type="primary" onTap="handleClick">打开日历选择</button>
<calendar visible="{{calendarVisible}}" value="{{calendarValue}}" isTabbar onClose="handleClick" onConfirm="handleCalendarConfirm" />
  <view style="width: 100%; margin-top: 100px; padding: 0 12px" a:if="{{calendarValue}}">
    您选择的日期是:{{calendarValue}}
  </view>

页面JS操作:

Page({
  data: {
    calendarValue: '', // 日历默认日期
    calendarVisible: false // 日历弹窗组件显示
  },
  handleClick() {
    this.setData({
      calendarVisible: !this.data.calendarVisible
    })
  },
  handleCalendarConfirm(e) {
    this.setData({
      calendarValue: e.value
    })
  }
});

开放属性内容

开放属性

属性类型

默认值

描述

type

String

range

single表示单选,range表示选择日期区间, 暂时只支持范围选择,单选的内部逻辑已保留,可基于源码进行二次开发

monthTranslate

Object

{}

日历上特殊日期加红蓝小圆点

visible

Boolean

false

日历弹窗显隐藏

isTabbar

Boolean

false

tabbar页面不需要底部安全区域的高度

bgColor

String

#FFFFFF

日历弹窗区域背景颜色,默认白色

limitTime

Number

90

限制用户只能选择从当天开始往后90天

value

String

‘2023-01-01,2023-01-08’

默认选中值|回填日历选中的值

onChangeTime

Function

{showYear: 2024, showMonth: 1}

获取显示时的年月

onGetCalendarTime

Function

{startTime: '2024-01-02', endTime: '2024-01-11'}

点击选择日期时,获取到的日期


组件只是给大家提供个思路,未做更多功能,目前符合我们的业务需求,不适合你们的业务的话就需要你们进行二次开发了。

日历组件demo | git地址:

https://github.com/minchangyong/ali-calendar

目录
相关文章
|
5月前
|
小程序
微信小程序如何实现进入小程序自动连WiFi功能
微信小程序如何实现进入小程序自动连WiFi功能
194 0
|
5月前
|
小程序 API
点餐小程序实战教程09-订单功能开发
点餐小程序实战教程09-订单功能开发
|
5天前
|
存储 自然语言处理 小程序
微信小程序多语言切换神器:简繁体切换功能完全指南
随着全球化的发展,支持多种语言的应用程序愈发重要。本文介绍了如何在微信小程序中实现简体与繁体字体之间的切换功能,以满足不同地区用户的需求。通过创建utils文件夹并编写相应的转换函数,开发者可以方便地实现语言切换,从而提升用户体验。文章中还附带了示例代码和效果图,帮助读者更好地理解和应用这一功能。
29 0
微信小程序多语言切换神器:简繁体切换功能完全指南
|
18天前
|
小程序 Linux Python
查找首字母与Python相关的的英文词汇小程序的续篇---进一步功能完善
查找首字母与Python相关的的英文词汇小程序的续篇---进一步功能完善
14 1
|
2月前
|
Web App开发 缓存 小程序
【Azure API 管理】从微信小程序访问APIM出现200空响应的问题中发现CORS的属性[terminate-unmatched-request]功能
【Azure API 管理】从微信小程序访问APIM出现200空响应的问题中发现CORS的属性[terminate-unmatched-request]功能
|
2月前
|
小程序 前端开发 开发者
|
2月前
|
小程序 前端开发 API
Ant Design Mini 问题之在微信小程序中,由于不支持slot特性,Ant Design Mini的什么组件功能受到了限制,如何解决
Ant Design Mini 问题之在微信小程序中,由于不支持slot特性,Ant Design Mini的什么组件功能受到了限制,如何解决
|
3月前
|
小程序 安全 数据挖掘
陪玩语聊APP小程序定制开发模块功能
随着电竞行业的规范化,游戏陪玩软件兴起,提供专业陪玩服务。核心功能包括:多样化注册登录、用户资料展示、智能匹配筛选陪玩、语音互动(多人/私聊)、订单交易管理、陪玩入驻审核、数据分析、客服系统及社交功能。旨在融合游戏、语音聊天与社交,构建综合娱乐平台。
|
3月前
|
小程序 BI 定位技术
广州跑腿小程序功能开发让生活更方便
跑腿小程序整合生活服务,提供快捷的跑腿任务解决方案。用户通过手机号或微信注册登录,发布如取快递、买饭等需求;跑腿员接单并利用导航高效完成。支持订单管理、多种支付方式及评价反馈系统,确保服务质量。小程序还发送订单状态通知,进行数据统计分析以促进平台发展。
|
3月前
|
存储 小程序 前端开发
如何设计小程序的站内信功能
如何设计小程序的站内信功能
146 0