1.如果你们要的是这种就继续往下看哈(日历多选

2.日期设置时间段仍可以选择当前日期区间 ,而我们要的是(今天4.22 我设置开始日期5.5,结束日期5.11,只有这个区间可以选择才符合我们的需求)如图

先说说第一点
Calendar 插件有一个change方法,返回选择的日期信息,so我们就要对这个方法进行下手。查看组件uni-calendar.vue中的choiceDate方法可得知每次选择日期信息,进而我们定义一个数组来接受我们每次选择的信息

choiceDate(weeks) {if (weeks.disable) returnthis.calendar = weeks//定义数组dateArr添加或删除日期值  fullDate 为选择的日期 2021-04-22if(this.dateArr.indexOf(this.calendar.fullDate)==-1) {console.log('tianjia')this.dateArr.push(this.calendar.fullDate)}else {var index= this.dateArr.indexOf(this.calendar.fullDate)this.dateArr.splice(index,1)}console.log(this.dateArr)// 设置多选console.log(this.calendar)this.cale.setMultiple(this.calendar.fullDate)this.weeks = this.cale.weeks//在change事件中返回值this.change()},

change事件种返回dateArr (setEmit方法中)

这一步完成后我们就可看到 自己选择的多个日期信息

接下来是 回显所选日期的样式了 找到uni-calendar-item.vue子组件,父子组件传值dateArr,在子组件操作:

当然我们也可以更改背景色等

.uni-calendar-item--checked {background-color: $uni-color-primary;color: #fff;opacity: 0.8;background-color: #FFD622;}

多选日历完成

第二点 日期范围不可选问题
找到插件的utils.js文件 找到**_currentMonthDys**这个方法,(图片为该方法中每天的日期信息,我们需要更改disable的值)

进而找到 dateCompare方法,更改这个方法的用途及逻辑

更改逻辑(_currentMonthDys方法中)

更改方法(拿一个月的每一天与开始和结束日期作比较,满足返回false,false为可选)

/*** 比较时间大小*/dateCompare(startDate, nowDate, endDate) {// 计算截止时间startDate = new Date(startDate.replace('-', '/').replace('-', '/'))nowDate = new Date(nowDate.replace('-', '/').replace('-', '/'))// 计算详细项的截止时间endDate = new Date(endDate.replace('-', '/').replace('-', '/'))if(startDate<=nowDate&&nowDate<=endDate) {return false}else {return true}// if (startDate <= endDate) {//   return true// } else {//    return false// }}
```第二点搞定~,原创不易,点赞支持i谢谢

uni-app 插件 Calendar 日历多选 (不是范围选择)相关推荐

  1. php日期控件calendar.js,轻量级的原生js日历插件calendar.js使用指南

    使用说明: 需要引入插件calendar.js/calendar.min.js 须要引入calendar.css 样式表,可以自定义自己想要的皮肤 本日历插件支持cmd模块化 如下调用:xvDate( ...

  2. 记一次easyui使用calendar日期插件实现日期多选

    easyui使用calendar日期插件实现日期多选 写在前面 需求 知己知彼 百战百胜 写完收工 写在前面 java开发,17年大专毕业.好不容易找个工作做了一年半左右结果行业不景气,我还没凉公司先 ...

  3. uni app中使用图表

    关于在uni app中运用图表 今天写项目,需要在uni app中使用图表,我使用的是ucharts. 具体操作如下 1.下载 ucharts可以直接在uni app的插件市场下载安装. 先在插件市场 ...

  4. uni app 自动化索引列表

    uni app 自动化索引列表,官方推荐的第三方插件 https://ext.dcloud.net.cn/plugin?id=375 [{"letter": "A&quo ...

  5. 日历 android 周历,Android Studio 基础 之 获取系统Calendar 日历日程 (涉及指定日期时间判断是星期几的方法使用)的方法整理...

    Android Studio 基础 之 获取系统Calendar 日历日程 (涉及指定日期时间判断是星期几的方法使用)的方法整理 目录 Android Studio 基础 之 获取系统Calendar ...

  6. uni app 开发微信小程序及上线体验

    uni app 开发微信小程序及上线体验 项目创建及微信小程序AppId的申请 本次开发的是电商类的微信小程序,这里用到的是HBuilderX这个编辑器.之前用的Visual Studio Code ...

  7. uni app 手机端导航栏自定义

    uni app 手机端导航栏自定义 第一步:明确顶部导航栏的构成(手机自带的顶部菜单+开发的顶部菜单栏) 获取手机自带的顶部导航栏 <view class="navigation_ba ...

  8. uniapp 日期插件_Calendar 日历

    更新记录 1.3.14(2020-05-22) 修复 自定义easycom规则,子组件提示未找到的Bug 1.3.13(2020-05-22) 修复 自定义easycom规则,子组件提示未找到的Bug ...

  9. Android Studio 基础 之 获取系统Calendar 日历日程(可获得当天以后可设定天数范围内的日历日程) (涉及指定日期时间判断是星期几的方法使用)的方法整理

    Android Studio 基础 之 获取系统Calendar 日历日程(可获得当天以后可设定天数范围内的日历日程) (涉及指定日期时间判断是星期几的方法使用)的方法整理 目录 Android St ...

最新文章

  1. php mysql 删除数据库,MySQL——删除数据库
  2. Python编程基础:第五十八节 线程Threading
  3. MATLAB报错“Exception in thread FileDecorationCache request queue java.lang.OutOfMemoryError: Java “
  4. kaggle 训练自己的cycleGan
  5. CentOS6.x 下 /etc/security/limits.conf 被改错的故障经历
  6. 学习笔记-------两阶段提交 2PC
  7. 两个数组结果相减_学点算法(三)——数组归并排序
  8. 35岁小贝荣膺终身成就奖
  9. C语言课后习题(34)
  10. 男女薪酬差异扩大 2018年女性薪酬不及男性8成?
  11. Python_今天是今年第几天
  12. 在Java中使用Rserve调用R
  13. git学习笔记-(3-linux基本命令)
  14. 刨根系列之volatile详解
  15. 蓝牙软件测试指标,手机软件测试蓝牙.pdf
  16. 机器人系统的基本概念及外部模型参数详解
  17. r7 5700u核显相当于什么显卡 R75700u相当于什么水平
  18. JS事件处理这一篇就够了!!
  19. pacman常见问题笔记
  20. JavaScript的concat方法

热门文章

  1. 如何快速开发一款蓝牙发射器?
  2. 解决逃离塔科夫0.12.9离线版修改商人可回收所有物品的问题
  3. linux如何实现端口复用nat,NAT地址转换和端口复用PAT
  4. windows的aow是通过什么实现的呢
  5. 微信读书vscode插件_VSCODE插件推荐
  6. 影视APP搭建教程四个步骤
  7. 跨越不可能:如何完成高且有难度的目标
  8. 文件管理类 第一期 | 整洁,从桌面开始
  9. 哈哈!没想到吧!Java也可以 实现微信和支付宝支付功能(附代码)
  10. Linux GoAccess 安装使用