Vant 日期时间组件拓展

news2025/1/11 14:47:49

基于 

"vant": "^4.8.3",

效果图

<template>
    <!-- 弹出层 -->
    <van-popup
        v-model:show="isPicker"
        position="bottom"
    >
      <van-picker
          ref="picker"
          :title="title"
          v-model="selectedValues"
          :columns="columns"
          @change="onChange"
          @cancel="cancelOn"
          @confirm="onConfirm"
      />
    </van-popup>
</template>

js

<script setup lang="ts">
import { ref ,watch } from 'vue';
import {formatTimeArray} from "@/utils/formate/date_formate";

const props = defineProps({
  showPicker: {
    type: Boolean,
    default: false,
  },
  title: {
    type: String,
    default: "请选择时间",
  },
  timeFormat: {
    type: String,
    default: "yyyy-MM-dd HH:mm:ss",
  },
})

const  isPicker = ref<any>(false) //是否显示弹出层
const  columns = ref<any>([])
const picker = ref()
const getCountDays = (year: any, month: any) => {
  //获取某年某月多少天
  const day = new Date(year, month, 0);
  return day.getDate();
}

const selectedValues = ref<any>(formatTimeArray(new Date()));

const getColumns = () => {
  const Y: any = selectedValues.value[0];
  const M: any = selectedValues.value[1];

  let year: any = []; // 默认范围 前后十年
  for (let i = Y - 10; i <= Y + 10; i++) {
    year.push({text: i,value: i});
  }

  let month: any ;//月
  month = getColumn(13,true)

  let days: any = getCountDays(Y, M); //天,和当年月有关
  let day: any;
  day = getColumn(days + 1,true)

  let hour: any ; //小时
  hour = getColumn(24)

  let minute: any ; //分钟
  minute = getColumn(60)

  let seconds: any ; //秒
  seconds = getColumn(60)

  if (props.timeFormat?.includes("yyyy")) {
    columns.value.push(year);
  }
  if (props.timeFormat?.includes("MM")) {
    columns.value.push(month); //获取当月的天数
  }
  if (props.timeFormat?.includes("dd")) {
    columns.value.push(day);
  }
  if (props.timeFormat?.includes("HH")) {
    columns.value.push(hour);
  }
  if (props.timeFormat?.includes("mm")) {
    columns.value.push(minute);
  }
  if (props.timeFormat?.includes("ss")) {
    columns.value.push(seconds);
  }
}

const getColumn = (length: any,isSplice: Boolean = false) => {
  if ( isSplice ) {
    const data = Array.from({ length }, (_, index) => ({ text: index, value: index }));
    return data.splice(1)
  } else {
    return Array.from({ length }, (_, index) => ({ text: index, value: index }));
  }
}

const onChange = (values: any) => {
  let days: any = getCountDays(values.selectedValues[0], values.selectedValues[1]);
  let newDayColumn: any ;
  newDayColumn = getColumn(days + 1,true);
  columns.value[2] = newDayColumn
}

const emits = defineEmits(["changeValue",'confirm']);

const cancelOn = () => {
  emits("changeValue");
};

const onConfirm = (val: any) => {
  let endVal: any = "";
  for (let i = 0; i < columns.value.length; i++) {
    endVal += val[i];
    if ( i === 2 ) {
      endVal += " ";
    } else if (i >= 3 && i <= 5) {
      endVal += ":";
    } else if (i < columns.value.length - 1) {
      endVal += "-";
    }
  }
  // 判断最后一个字符是否是分隔符
  if (endVal.endsWith("-") || endVal.endsWith(":")) {
    endVal = endVal.slice(0, -1); // 删除最后一个字符
  }
  emits("changeValue", endVal);
  emits("confirm", val.selectedValues);

}

// 监听 isPicker 的变化
watch(isPicker, (val: any) => {
  if (!val) {
    emits("changeValue");
  }
  columns.value = [];
  getColumns();
});

// 监听 showPicker 的变化
watch(() => props.showPicker, (val) => {
  isPicker.value = val;
});


</script>

引用组件

 <DateTimePicker
          @changeValue="showEndPicker = false"
          ref="popup"
          :showPicker="showEndPicker"
          @confirm="onEndConfirm"
      />

结合 输入框一起使用

      <van-field
          class="form-wrapper"
          v-model="formData.pzzy_enddate"
          is-link
          required
          label-width="130"
          name="datePicker"
          label="批准作业结束时间"
          placeholder="点击选择时间"
          @click="showEndPicker = true"
      />
      <DateTimePicker
          @changeValue="showEndPicker = false"
          ref="popup"
          :showPicker="showEndPicker"
          @confirm="onEndConfirm"
      />

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

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

相关文章

匿名管道和命名管道

目录 管道 pipe创建一个管道 让子进程写入&#xff0c;父进程读取 如何把消息发送/写入给父进程 父进程该怎么读取呢 管道本质 结论&#xff1a;管道的特征&#xff1a; 测试管道大小 写端退了&#xff0c;测试结果 测试子进程一直写&#xff0c;父进程读一会就退出 …

PAT甲级-1076 Forwards on Weibo

题目 题目大意 已知微博上粉丝都可能会转发自己所关注的人的动态&#xff0c;给定总人数n和层数l&#xff0c;和每个id关注的人数及所关注人的id。要求查询一组用户的潜在转发量&#xff0c;粉丝层级不能超过l。 思路 求潜在转发量&#xff0c;就是一层一层的找粉丝数&#…

【已知当前表字段名注入】

一、通配符注入 like 测试注入 usernameadmin&passwordadmin 提示username or password error输入单引号闭合测试 这里用or防止admin字段不存在数据库中&#xff0c;如果admin不存在用and连接admin不为真&#xff0c;username的逻辑还是没绕过&#xff0c;用or就算我们前面…

嵌入式Linux开发板配置静态IP

嵌入式Linux开发板配置静态IP Chapter1 嵌入式Linux开发板配置静态IPChapter2 Linux命令之hwclock - 查询和设置硬件时钟 Chapter1 嵌入式Linux开发板配置静态IP 修改interfaces配置文件&#xff0c;普通用户interfaces文件权限只可读&#xff0c;首先切换到root权限。 sudo …

vue单页面 与多页面的区别

引用&#xff08;【Vue相关】单页面应用(SPA)与多页面应用(MPA)的区别_vue mpa-CSDN博客&#xff09; 只要用框架基本上都是单页面工程

特斯拉全新发布会上,无人驾驶汽车亮相,机器人与用户近距离互动

在科技日新月异的今天&#xff0c;特斯拉再次以其前瞻性的技术和创新理念引领了行业的潮流。近日&#xff0c;特斯拉在美国加利福尼亚州伯班克华纳兄弟工作室召开了一场主题为“WE ROBOT”的新品发布会&#xff0c;会上不仅发布了无人驾驶汽车&#xff0c;还展示了特斯拉人形机…

4S店汽车行业专业线上小程序源码系统 功能强大 带完整的安装代码包以及搭建部署教程

系统概述 随着移动互联网的迅速发展&#xff0c;越来越多的传统行业开始拥抱数字化转型。在汽车销售领域&#xff0c;4S店&#xff08;即集整车销售、零配件供应、售后服务、信息反馈四位于一体的汽车服务企业&#xff09;也不例外。为了更好地服务于客户&#xff0c;并提升自…

C++11——异常

异常的介绍 异常是C1中的一种处理错误的方式&#xff0c;当某一函数发现自己无法处理的错误时就可以抛出异常&#xff0c;让函数的直接或间接的调用者处理这个错误&#xff0c;异常的使用可以避免一些难以发现的bug被更好的发现并被处理。 异常的使用 异常的使用包含是三个部…

从空口分析BLE AUDIO ASCS

ASCS&#xff1a;AUDIO STREAM CONTROL SERVICE&#xff0c;音频流控制服务&#xff0c;顾名思义会对音频流的一些参数去做控制的服务&#xff0c;下面我们还是以手机和耳机为例&#xff0c;结合空口来分析ASCS都有哪些内容&#xff1a; 1&#xff1a;ASE CODEC CONFIG 配置A…

保姆级教程下载finalshell以及连接云服务器基础的使用教程

废话不多说&#xff0c;我们直接进行安装 一、软件下载 下载地址&#xff1a; FinalShell SSH工具,服务器管理,远程桌面加速软件,支持Windows,macOS,Linux,版本4.5.10,更新日期2024.9.26 - FinalShell官网 (hostbuf.com)https://www.hostbuf.com/t/988.html 点击链接进行下载…

【Next.js 项目实战系列】01-创建项目

原文链接 CSDN 的排版/样式可能有问题&#xff0c;去我的博客查看原文系列吧&#xff0c;觉得有用的话&#xff0c;给我的库点个star&#xff0c;关注一下吧 创建项目 创建项目​ 在创建项目中可以找到相关内容&#xff0c;这里不再赘述 First commit​ 创建好项目之后&am…

40个IT运维加薪技术,每一个都含金量极高!运维必会的10个网络抓包/调试工具!系统崩溃的10种可能,运维人员必看!

40个IT运维加薪技术&#xff0c;每一个都含金量极高!运维必会的10个网络抓包/调试工具&#xff01;系统崩溃的10种可能&#xff0c;运维人员必看&#xff01; 在IT运维领域&#xff0c;想要加薪并不仅仅依赖于单一的技术&#xff0c;而是需要综合运用多种技能&#xff0c;不断提…

【LangChain】(一)掌握向量数据库的CRUD操作与语义检索技巧

文章目录 1. 向量数据库的基础知识1.1 为什么选择向量数据库&#xff1f; 2. CRUD操作详解2.1 向量数据库-新增数据示例代码&#xff1a; 2.2 向量数据库-删除数据示例代码&#xff1a; 2.3 向量数据库-更新数据2.4 向量数据库-查询数据2.4.1 相似度查询2.4.2 最大边际相关性查…

React(二) JSX中的this绑定问题;事件对象参数传递;条件渲染;列表渲染;JSX本质;购物车案例

文章目录 一、jsx事件绑定1. 回顾this的绑定方式2. jsx中的this绑定问题(1) 方式一&#xff1a;bind绑定(2) 方式二&#xff1a;使用 ES6 class fields 语法(3) 方式三&#xff1a;直接传入一个箭头函数(重要) 3.事件参数传递(1) 传递事件对象event(2) 传递其他参数 4. 事件绑定…

DeepBook V3和DEEP token正式上线

10月14日&#xff0c;DeepBook V3版本正式在主网上线&#xff0c;同时发布了DEEP token&#xff0c;标志着其发展历程中的一个重要里程碑。通过这次升级&#xff0c;用户和做市商将受益于精细调控的激励措施&#xff0c;为通过社区驱动的治理实现更大的去中心化奠定了基础。 D…

【大模型问答测试】大模型问答测试脚本实现(第一版)

背景 公司已经做了一段时间的大模型&#xff0c;每次测试或者回归的时候都需要针对问答进行测试回归&#xff0c;耗费大量的时间与精力&#xff0c;因此结合产品特点&#xff0c;开发自动化脚本替代人工的操作&#xff0c;提升测试回归效率 设计 使用pythonrequestExcel进行…

python+大数据+基于Spark的共享单车数据存储系统【内含源码+文档+部署教程】

博主介绍&#xff1a;✌全网粉丝10W,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业毕业设计项目实战6年之久&#xff0c;选择我们就是选择放心、选择安心毕业✌ &#x1f345;由于篇幅限制&#xff0c;想要获取完整文章或者源码&#xff0c;或者代做&am…

【jQuery】 jQuery基础及选择器介绍(基本选择器 层次选择器 属性选择器 过滤选择器)

文章目录 jQuery基础1. 优势2. 版本3. 基本语法4. 选择器基本选择器层次选择器属性选择器过滤选择器基本过滤选择器可见性过滤选择器 注意事项 jQuery基础 jQuery 是一个功能强大且易于使用的 JavaScript 库&#xff0c;它极大地简化了前端开发的工作。无论是 DOM 操作、事件处…

简单概述Ton链开发路径

区块链开发领域发展迅速&#xff0c;各种平台为开发人员提供不同的生态系统。其中一个更有趣且越来越相关的区块链是TON&#xff08;开放网络&#xff09;区块链。TON 区块链最初由 Telegram 构思&#xff0c;旨在提供快速、安全且可扩展的去中心化应用程序 (dApp)。凭借其独特…

加盟模式如何运营?有哪些好的技巧和方法!

对于很多品牌方来说&#xff0c;生意发展到一定程度&#xff0c;就考虑通过加盟的方式扩大市场份额。 本篇文章&#xff0c;将从3个角度来为大家分享&#xff0c;运营加盟模式的好方法和技巧&#xff01; 一、加盟前的准备 1、明确品牌定位与核心竞争力 确定你的企业在市场…