明殊 2022-09-23 14:46 采纳率: 100%
浏览 57
已结题

移动端react react-mobile-datepicker 日期范围选择

问题遇到的现象和发生背景

现想写一个移动端的日期范围选择器,日期只到天,例如: 2022-09-01~2022-10-01

用代码块功能插入代码,请勿粘贴截图
我的解答思路和尝试过的方法

目前写好后的效果是

img


但是只能到月份,而且点击确定,拿不到选择的日期填进去

我想要达到的结果

img

  • 写回答

2条回答 默认 最新

  • 明殊 2022-10-20 15:18
    关注

    可用组件处理
    import {Calendar } from 'antd-mobile';
    inpValu:'', //日期回填参数
    getModalStatus:false, //控制日期组件的显示和隐藏
    startTime: dayjs().subtract(0, 'day').toDate(), // 开始时间
    endTime: '', // 结束时间

    /**
         * 点击筛选日期
         */
         openDate = ()=>{
          this.setState({
            getModalStatus:true
           })  
       }
       
       /**
        * 关闭筛选日期模态框
        */
       close= ()=>{
    
           this.setState({
            getModalStatus:false
           })  
    
       }
    /**设置时间 */
      setTime(val){
        this.setState({startTime:val[0],endTime: val[1]});
      }
      /**确定时关闭日期选择页面 */
      setVal =(val) =>{
        this.setState({startTime:val[0],endTime: val[1]});
        var st = this.dateFormat(this.state.startTime);
        var et = this.dateFormat(this.state.endTime);
        var dateTime = st + '~ ' + et;
        console.log('开始时间:'+st);
        console.log('结束时间:'+et);
        console.log(st + '~ ' + et);
        if(!this.isNull(st) && !this.isNull(et)){
        this.close();
        }
        this.setState({inpValu:dateTime});
      }
        /**
         * 日期格式化
         */
        dateFormat(date){
          if(date){
            var Y = date.getFullYear() + '-';
            var M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
            var D = date.getDate() < 10 ? '0' + date.getDate() + ' ':date.getDate() + ' ';
            return Y+M+D;
          }else{
            return '';
          }
        }
    在render里面
    <div
                  style={{ display: this.state.getModalStatus ? "block" : "none" }}
                >
                  <Calendar
                    selectionMode="range"
                    defaultValue={defaultRange}
                    onChange={(val) => {
                      this.setTime(val);
                    }}
                  />
                  <Button className='cancel' size='small' onClick={this.close}>
                    取消
                  </Button>
                  <Button className='sure' size='small' onClick={this.setVal}>
                    确定
                  </Button>
              </div>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月28日
  • 已采纳回答 10月20日
  • 创建了问题 9月23日

悬赏问题

  • ¥15 linux驱动,linux应用,多线程
  • ¥20 我要一个分身加定位两个功能的安卓app
  • ¥15 基于FOC驱动器,如何实现卡丁车下坡无阻力的遛坡的效果
  • ¥15 IAR程序莫名变量多重定义
  • ¥15 (标签-UDP|关键词-client)
  • ¥15 关于库卡officelite无法与虚拟机通讯的问题
  • ¥15 目标检测项目无法读取视频
  • ¥15 GEO datasets中基因芯片数据仅仅提供了normalized signal如何进行差异分析
  • ¥100 求采集电商背景音乐的方法
  • ¥15 数学建模竞赛求指导帮助