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

移动端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 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵