elmentUI组建中el-date-picker实现限制时间范围精确到小时

news2024/12/25 14:40:10

elmentUI组建中el-date-picker实现限制时间范围精确到小时

需求要求

  1. 时间选择器只能选择今天之前的日期.默认时间是前一天00点~23点
  2. 后台返回的最小时间和最大时间
  3. 时间精度限制到小时
    开始想着用type="datetimerange"来实现,后来发现控制时间禁用无法实现,后改变思路使用两个type="datetime"拼装

实现

1.先获取一个只能选择到小时的时间范围选择器

css代码

<el-date-picker
            v-model="validity1"
            type="datetime"
            value-format="yyyy-MM-dd HH"
            format="yyyy/MM/dd HH"
            class="datepicker-content"
            :picker-options="datapickerOptions1"
            popper-class="datepickerPopperClass"
            @change="changeDatetime"
            placeholder="起始时间"
            :clearable="false"
          >
          </el-date-picker>
          ~
          <el-date-picker
            v-model="validity2"
            type="datetime"
            value-format="yyyy-MM-dd HH"
            format="yyyy/MM/dd HH"
            class="datepicker-content"
            popper-class="datepickerPopperClass"
            :picker-options="datapickerOptions2"
            placeholder="结束时间"
            :disabled="!validity1"
            :clearable="false"
          >
          </el-date-picker>

如何实现精度到小时,使选择器只能选择到时间(如图)
在这里插入图片描述

通过修改css样式实现代码,隐藏分秒结构

.datepickerPopperClass{
  .el-button--text{
    display: none;  //删除时间弹框中此刻按钮(根据需求决定是否保留)
  }
  .el-time-spinner__wrapper{
    width:100%;
  }
  .el-scrollbar:nth-child(2){
    display: none;
  }
}

这样结构上就有一个只能选择到小时的时间范围选择器,这里结束时间在没有选择开始时间时是禁用的

2.通过picker-options属性来控制时间可选日期范围

其中disabledDate属性值来控制选择的日期范围,selectableRange属性值控制可选择的小时范围
vue中data中声明的变量

data() {
    return {
      validity1:'',
      selectableRange1:"00:00:00 - 23:59:59",
      validity2:"",
      selectableRange2:"00:00:00 - 23:59:59",
      startTime:"",   //从后台获取的库表生成时间,之前的时间不能选择,这个值可以根据你需求中的时间来赋值
      endTime:"",      //数据库结束时间
      datapickerOptions1: {
        //设置不能选择的日期
        selectableRange: this.selectableRange1,
        disabledDate: (time) => {
          //获取当前时间
          let nowDate = new Date();
          const oneHour = 1 * 3600 * 1000; //一个小时
          let defaultTime = this.formatDate(nowDate.getTime()-oneHour,"yyyy-MM-dd hh")
          let startTime = this.startTime.split(' ')[0]+" 00:00:00" 
          defaultTime = defaultTime + ":59:59"
          return time.getTime() > new Date(defaultTime)||time.getTime() < new Date(startTime);
        },
      },
      datapickerOptions2: {
        //设置不能选择的日期
        selectableRange: this.selectableRange2,
        disabledDate: (time) => {
          //获取当前时间
          let nowDate = new Date();
          const oneHour = 1 * 3600 * 1000; //一个小时
          let defaultTime = this.formatDate(nowDate.getTime()-oneHour,"yyyy-MM-dd hh")
          let validityTime = this.validity1.split(' ')[0]+" 00:00:00"
          defaultTime = defaultTime + ":59:59"
          return time.getTime() > new Date(defaultTime)||time.getTime() < new Date(validityTime);
        },
      },
    };
  },

通过watch来监控起始时间和结束时间,日期选择后,相应的小时选择范围也会变化

watch:{
    validity1: {
      // date-picker控件点x清空之后默认会重置为null,监听设置为["",""]
      handler(newVal) {
        if (newVal) {
          // console.log("newVal",newVal)
          // console.log(this.startTime)
          if(new Date(newVal+":00:00").getTime()<new Date(this.startTime).getTime()){
            this.validity1 = this.formatDate(this.startTime.split(' ')[0],"yyyy-MM-dd") + " " + this.startTime.split(' ')[1].split(':')[0]+":00"
            // console.log("validity1",this.validity1)
          }
          let rangeStart = ""
          let rangeEnd = ""
          //如果选择的日期是后台库表初始日期
          if(this.startTime){
            if(newVal.split(' ')[0]==this.formatDate(this.startTime.split(' ')[0],"yyyy-MM-dd")){
              rangeStart = this.startTime.split(' ')[1]
            }else{
              rangeStart = "00:00:00"
            }
          }else{
            rangeStart = "00:00:00"
          }
          if(this.endTime){
            if(newVal.split(' ')[0]==this.formatDate(this.endTime.split(' ')[0],"yyyy-MM-dd")){
              rangeEnd = this.endTime.split(' ')[1]
            }else{
              rangeEnd = "23:59:59"
            }
          }else{
            rangeEnd = "23:59:59"
          }
          this.selectableRange1 = rangeStart + " - " + rangeEnd
          this.$set(this.datapickerOptions1,"selectableRange",this.selectableRange1)
        }
      },
      immediate: true,
      deep: true,
    },
    validity2: {
      // date-picker控件点x清空之后默认会重置为null,监听设置为["",""]
      handler(newVal) {
        if (newVal) {
          // console.log("newVal",newVal)
           if(new Date(newVal).getTime()<new Date(this.validity1).getTime()){
            this.validity2 = this.validity1.split(':')[0]+ ":59"
          }
          let rangeStart = ""
          let rangeEnd = ""
          //如果选择的日期是后台库表初始日期
          if(new Date(newVal.split(' ')[0]).getTime()==new Date(this.validity1.split(' ')[0]).getTime()){
            rangeStart = this.validity1.split(' ')[1].split(':')[0] + ":59:59"
          }else{
            this.selectableRange2 = "00:59:59"
          }
          if(this.endTime){
            if(newVal.split(' ')[0]==this.formatDate(this.endTime.split(' ')[0],"yyyy-MM-dd")){
              rangeEnd = this.endTime.split(' ')[1]
            }else{
              rangeEnd = "23:59:59"
            }
          }else{
            rangeEnd = "23:59:59"
          }
          this.selectableRange2 = rangeStart + " - " + rangeEnd
          this.$set(this.datapickerOptions2,"selectableRange",this.selectableRange2)
        }
      },
      immediate: true,
      deep: true,
    },
  },

其中用到的时间格式化方法formatDate

filters: {
    formatDate: function(time) {
      if (time != null && time != "") {
        var date = new Date(time);
        return formatTimeToStr(date, "yyyy/MM/dd hh:mm:ss");
      } else {
        return "";
      }
    },
  },

date.js

export function formatTimeToStr(times, pattern) {
    var d = new Date(times).Format("yyyy-MM-dd hh:mm:ss");
    if (pattern) {
        d = new Date(times).Format(pattern);
    }
    return d.toLocaleString();
}

起始时间选择后,结束时间才可以显示同时结束时间清空

changeDatetime(){
    this.validity2 = ""
   },

希望对你有帮助

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/128160.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SkyEye助力飞控软件Debug

​01.Debug是什么&#xff1f; 1947年9月9日&#xff0c;美国著名科学家格蕾丝.霍普&#xff08;Grace Hopper&#xff09;与其同伴在对Mark II计算机进行研究时发现&#xff0c;导致计算机无法正常工作的罪魁祸首居然是一只粘在继电器上的小飞蛾。格蕾丝用镊子将飞蛾夹出&…

在腾讯、阿里、字节技术岗工作十年能挣普通公务员一辈子的钱吗?

在腾讯、阿里、字节技术岗工作十年&#xff0c;能挣到普通公务员一辈子的钱&#xff0c;但不一定能存到普通公务员一辈子的钱。 大厂程序员 VS 普通公务员谁更香&#xff0c;一直是争论不断的话题&#xff0c;让我们站在程序员的角度&#xff0c;来回答这一问题。 大厂程序员V…

打造智慧社区数字孪生应用新范式

近日&#xff0c;民政部、中央政法委、中央网信办、国家发展改革委等部门印发了《关于深入推进智慧社区建设的意见》&#xff0c;明确指出依托智慧社区综合信息平台&#xff0c;创新政务服务、公共服务提供方式&#xff0c;推动就业、健康、卫生、等服务“指尖办”、“网上办”…

家装市场“攻守道”

不同于很多属于弹性需求的消费行业&#xff0c;“住”属于刚性需求&#xff0c;因此家装就成为了人们日常生活中的重要交易场景。据《疫情下的家居消费心态调查》问卷显示&#xff0c;60%以上的居民不会因为疫情而放弃装修。大量的装修需求激发了家装的活力&#xff0c;家装市场…

Node.js 模块化(二) 开发包/模块加载机制

1. 开发属于自己的包 1. 需要实现的功能 2. 初始化包的基本结构 3. 初始化 package.json 属性&#xff1a; name&#xff1a;包的名称&#xff08;不能重复&#xff0c;在官网检索一下&#xff0c;避免重复&#xff09; version&#xff1a;版本号 main&#xff1a;入口文件&a…

如何下载并生成等高线

如何下载并生成等高线 发布时间&#xff1a;2018-01-17 版权&#xff1a; 同步视频教程&#xff1a;下载高程等高线使用视频教程-Bigemap GIS Office 专题地图制作视频教程&#xff1a;地图数据应用&#xff08;制作地图效果的基本过程&#xff09;-Bigemap GIS Office 视频…

【vue】关于路由的使用

&#xff08;1&#xff09;路由步骤 根据官方的文档&#xff0c;我们的路由大概需要以下的几种构成 &#xff08;1&#xff09;首先引入组件 &#xff08;2&#xff09;创建routes布局 &#xff08;3&#xff09;创建router对象 &#xff08;4&#xff09;抛出 &#xff0…

最长公共子序列

最长公共子序列一、题目二、思路1、状态转移方程&#xff08;1&#xff09;状态表示&#xff08;2&#xff09;状态转移2、循环设计三、代码一、题目 二、思路 这道题是一个很经典的DP问题&#xff0c;那么我们来看一下如何分析。 DP问题我们需要考虑两个问题&#xff1a;第一…

【Javassist】快速入门系列11 当检测到显示类型转换时用代码块替换

系列文章目录 01 在方法体的开头或结尾插入代码 02 使用Javassist实现方法执行时间统计 03 使用Javassist实现方法异常处理 04 使用Javassist更改整个方法体 05 当有指定方法调用时替换方法调用的内容 06 当有构造方法调用时替换方法调用的内容 07 当检测到字段被访问时使用语…

深度剖析钓鱼网站域名识别工具dnstwist

大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名,科大讯飞比赛第三名,CCF比赛第四名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的见解。曾经辅导过若干个非计算机专业的学生进入到算法…

漫途设备远程运维平台在制造业中的应用!

我国正处于从制造大国向制造强国迈进的关键时期&#xff0c;制造业的数字化、网络化、智能化以及绿色制造体系&#xff08;双碳为代表&#xff09;的打造事关制造业全局&#xff0c;是制造业高质量、可持续发展的关键与重要着力点。而设备智能运维是智能制造行业的短板。 存在以…

回归童年的美好 守住童年的回忆 那些年你玩过的游戏都有呢

时过迁境&#xff0c;曾经与我们一同玩耍的发小、同学&#xff0c;也因为工作、家庭原因早已各奔东西不在自己的身边。 还依稀记得孩童时期和小伙伴们一同蹲在大头电视前&#xff0c;快乐的玩着红白机的魂斗罗、超级玛丽还有炸弹人。稍微长大后&#xff0c;家里有了大头显示器…

ArcGIS基础实验操作100例--实验19按值修改栅格值

本实验专栏来自于汤国安教授《地理信息系统基础实验操作100例》一书 实验平台&#xff1a;ArcGIS 10.6 实验数据&#xff1a;请访问实验1&#xff08;传送门&#xff09; 基础编辑篇--实验19 按值修改栅格值 目录 一、实验背景 二、实验数据 三、实验步骤 &#xff08;1&am…

Winsock套接字开发网络聊天室实例(C/S)模式

聊天室的基本要求 聊天器采用客户端/服务器&#xff08;C/S&#xff09;模式&#xff1b; 1&#xff0c;客户端利用UDP与服务器连接&#xff0c;客户端与客户端之间通过UDP互相通讯&#xff1b; 2&#xff0c;服务器端具有服务器端口设置&#xff0c;维护客户端个人信息&#…

SQL INNER JOIN:内连接

INNER JOIN 是 SQL 中最重要、最常用的表连接形式&#xff0c;只有当连接的两个或者多个表中都存在满足条件的记录时&#xff0c;才返回行。 SQL INNER JOIN 子句将 table1 和 table2 中的每一条记录进行比较&#xff0c;以找到满足条件的所有记录&#xff0c;然后将每一对满足…

YGG 公会发展计划(GAP)第二季总结

Yield Guild Games&#xff08;YGG&#xff09;正在结束其公会发展计划&#xff08;GAP&#xff09;的第二季&#xff0c;这是一个成就驱动的社区代币分配协议&#xff0c;奖励 YGG 成员通过优质贡献为公会提供价值。 第二季的 GAP 包括 117 个任务式的「成就」&#xff0c;为了…

有向图的概念和java代码实现

有向图定义 有向图是一副具有方向性的图&#xff0c;是由一组顶点和一组有方向的边组成的&#xff0c;每条方向的边都连着一对有序的顶点。 出度&#xff1a; 由某个顶点指出的边的个数称为该顶点的出度。 入度&#xff1a; 指向某个顶点的边的个数称为该顶点的入度。 有向路径…

重学redux之Redux Toolkit(四)

更新第四篇了,这篇是最终篇,没有基础的最好看看前几篇,篇幅有限,更多的是一个指导,如果有不清楚的地方,可评论区留言(最好自己找度娘问问),引用官方说话,先来了解一下 redux toolkit 是什么东西 Redux Toolkit 是什么? Redux Toolkit 是 Redux 官方强烈推荐,开箱…

用JavaScript实现网页雪花飘落特效

不知道大家有没有看到过别人的网页有雪花飘落的特效&#xff0c;我当时看到真的觉得好好看&#xff0c;于是乎就去借鉴别人做的特效代码&#xff0c;最终将这个特效成功放到自己做的网页上啦~代码放到下面啦&#xff0c;可以自己设置颜色&#xff0c;雪花形状的大小&#xff0c…

新政策|“信息科技”独立设置为新科目

近日&#xff0c;教育部印发义务教育课程方案和语文等16个课程标准(2022年版)。今天&#xff0c;教育部召开新闻发布会&#xff0c;介绍《义务教育课程方案和课程标准&#xff08;2022年版&#xff09;》。 教育部教材局局长田慧生表示&#xff0c;现行义务教育课程方案和课程…