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

移动端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日

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!