IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> layui.laydate开始时间与结束时间间隔30天 -> 正文阅读

[JavaScript知识库]layui.laydate开始时间与结束时间间隔30天

layui.layuidate的实现需满足以下3点:

  1. 选择开始时间后,点击确定,开始时间显示
  2. 选择设置结束时间:(结束时间范围: [选择的开始时间+30 备注:最远可选择的是第30天,可以在30内进行其他日期的选择
  3. 如果修改开始时间,结束时间自动清空。

刚开始写的时候,我的问题主要是:再次修改开始日期的时候,那个结束的日期范围就没有更新。

解决方法是:切换选择开始日期后删除结束日期元素,再次添加新的元素。

$("#dateChangeEnd").remove();
$(".date-text").after(
'<input type="text" class="layui-input" style="width: 260px;margin-left: 10px;" lay-verify="required" id="dateChangeEnd" name="endTime">')

完整代码如下:
html:

   <div class="qrcode-right-list qrcode-time">
        <input type="text" class="layui-input" style="width: 260px;margin-right: 10px;" lay-verify="required" id="dateChangeStart" name="startTime" />
        <span class="date-text">至:</span>
        <input type="text" class="layui-input" style="width: 260px;margin-left: 10px;" lay-verify="required" id="dateChangeEnd" name="endTime" />
      </div>

js:

    // 开始日期结束日期
    laydate.render({
      elem: '#dateChangeStart',
      type: 'datetime',
      min: 0,  //最小是当天的日期
      format: 'yyyy-MM-dd HH:mm:ss',
      trigger: 'click',
      done: function (value, date, endDate) {
        $("#dateChangeEnd").remove();
        $(".date-text").after(
        '<input type="text" class="layui-input" style="width: 260px;margin-left: 10px;" lay-verify="required" id="dateChangeEnd" name="endTime">')
        console.log("初次选择是否会触发",value,getMinDate(value));
          laydate.render({
          elem: '#dateChangeEnd',
          trigger: 'click',
          type: 'datetime',
          min:0,
          max:getMinDate(value),
          format: 'yyyy-MM-dd HH:mm:ss',
          trigger: 'click',
          done: function (value, date, endDate) {
            var startDate = $("input[name='startTime']").val();
            if (startDate == value) {
              return layer.msg('开始结束日期不可设置相同');
            } else {
              return true
            }
          }
        }); 
      }
      ,change: function(value, date, endDate){
        $("#dateChangeEnd").val('') 
      }
    });

    // 计算开始时间推迟后30天
    function getMinDate(time){
     console.log(3333,time)
     var date1 = new Date(time);
     var date2 = new Date(date1);
     date2.setDate(date1.getDate() + 30);
     var year = date2.getFullYear();     
     var month = date2.getMonth() + 1 <10 ? `0${date2.getMonth() + 1}` :  date2.getMonth() + 1;  
     var data = date2.getDate() < 10 ? `0${date2.getDate()}` : date2.getDate();        
     var hour = date2.getHours() < 10 ? `0${date2.getHours()}` : date2.getHours();   
     var min = date2.getMinutes() <10 ? `0${date2.getMinutes()}` : date2.getMinutes();  
     var sec = date2.getSeconds() <10 ? `0${date2.getSeconds()}` : date2.getSeconds(); 
     return year + "-" + month + "-" + data + " "+ hour + ":" + min + ":" + sec
    }

  })

效果展示:
在这里插入图片描述
如果大家有更好更多的解决方法,欢迎评论区留言😁

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-15 11:32:29  更:2022-05-15 11:32:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 5:44:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码