uniapp日期区间选择器

uniapp日期区间选择器

在 uniapp 中创建一个简单的自定义日期范围的日期区间选择器:

  • 限制有效日期范围开始日期为 2024-01-01,结束日期为当日;

  • 默认日期区间为当日向前计算的7日区间;

  • 选择开始时间后,判断不可大于结束时间,且重置开始时间为结束时间;

  • 选择结束时间后,判断不可小于开始时间,且重置结束时间为开始时间;

示例代码:

html:

html 复制代码
<view class="picker-container">
  <view class="picker-item">
    <view class="picker-item-title">开始日期 :</view>
    <picker mode="date" :value="startDate" start="2024-01-01" :end="todayDate" @change="bindStartDateChange">
      <view>{{startDate}}</view>
    </picker>
  </view>
  <view class="picker-item">
    <view class="picker-item-title">结束日期 :</view>
    <picker mode="date" :value="endDate" start="2024-01-01" :end="todayDate" @change="bindEndDateChange">
      <view>{{endDate}}</view>
    </picker>
  </view>
</view>

CSS:

css 复制代码
.picker-container{ height: 80rpx; font-size: 26rpx; display: flex; justify-content: space-around; align-items: center; border-radius: 10rpx; background-color: #fff;}
.picker-item{ padding: 16rpx; display: flex; justify-content: space-around; align-items: center;}
.picker-item-title{ color: #999; white-space: nowrap;}
.picker-item picker{ flex: 1; color: #8B4F8E; font-weight: bold;}

data设置参数数据:

javascript 复制代码
data() {
  return {
    todayDate:'',
    startDate: '',
    endDate: '',
  }
},

created 或 onLoad 中,调用初始化日期区间方法:

javascript 复制代码
this.setInitTime();

methods 处理方法:

javascript 复制代码
setNum(num){
  if(num < 10){
    return '0' + num;
  }else{
    return num;
  }
},
setInitTime(){
  let thisTime = new Date();
  this.todayDate = thisTime.getFullYear() + '-' + this.setNum(thisTime.getMonth() + 1) + '-' + this.setNum(thisTime.getDate());
  let startTime = new Date(thisTime - (24 * 60 * 60 * 1000 * 6));
  this.startDate = startTime.getFullYear() + '-' + this.setNum(startTime.getMonth() + 1) + '-' + this.setNum(startTime.getDate());
  this.endDate = this.todayDate;
  this.getData();
},
bindStartDateChange(e) {
  if(new Date(e.detail.value) > new Date(this.endDate)){
    // 开始时间不可大于结束时间
    this.startDate = this.endDate;
  }else{
    this.startDate = e.detail.value;
  }
  this.getData();
},
bindEndDateChange(e) {
  if(new Date(e.detail.value) < new Date(this.startDate)){
    // 结束时间不可小于开始时间
    this.endDate = this.startDate;
  }else{
    this.endDate = e.detail.value;
  }
  this.getData();
},

getData(){
  // 获取对应时间段数据
  console.log(this.startDate.replace(/-/g,'/') + '-' + this.endDate.replace(/-/g,'/'))
},
相关推荐
excel13 小时前
Node.js 断言与测试框架示例对比
前端
天蓝色的鱼鱼14 小时前
前端开发者的组件设计之痛:为什么我的组件总是难以维护?
前端·react.js
codingandsleeping14 小时前
使用orval自动拉取swagger文档并生成ts接口
前端·javascript
石金龙15 小时前
[译] Composition in CSS
前端·css
白水清风15 小时前
微前端学习记录(qiankun、wujie、micro-app)
前端·javascript·前端工程化
Ticnix16 小时前
函数封装实现Echarts多表渲染/叠加渲染
前端·echarts
用户221520442780016 小时前
new、原型和原型链浅析
前端·javascript
阿星做前端16 小时前
coze源码解读: space develop 页面
前端·javascript
叫我小窝吧16 小时前
Promise 的使用
前端·javascript
NBtab16 小时前
Vite + Vue3项目版本更新检查与页面自动刷新方案
前端