当前位置: 首页 > article >正文

vue3+element-plus el-date-picker日期、年份筛选设置本周、本月、近3年等快捷筛选

一、页面代码:

<template>

<!-- 日期范围筛选框 -->

<el-date-picker

          v-model="dateRange"

          value-format="YYYY-MM-DD"

          type="daterange"

          range-separator="至"

          start-placeholder="开始日期"

          end-placeholder="结束日期"

          :shortcuts="shortcuts"

          placement="bottom-start"

          :editable="false"

          :disabled-date="disabledDate"

          @change="changeDate"

          class="date-select"

        />

<!-- 年份范围筛选框 -->

<el-date-picker

        v-model="yearRange"

        value-format="YYYY"

        type="yearrange"

        range-separator="至"

        start-placeholder="开始年份"

        end-placeholder="结束年份"

        :shortcuts="shortcuts1"

        placement="bottom-start"

        :editable="false"

        :disabled-date="disabledYear"

        @change="changeYear"

        @clear="changeYear1"

        class="date-select"

        ref="yearPicker"

      />

</template>

<script setup lang="ts">

import common from '@/utils/common'

const startDate = ref<any>() // 开始时间

const endDate = ref<any>() //结束时间

const dateRange = ref<any>([]) // 日期范围值

const yearPicker = ref() // 年份筛选框ref

const yearRange = ref<any>([]) // 年份范围值

// 日期快捷选项

const shortcuts = [

  {

    text: '今日',

    value: () => {

      const end = new Date()

      const start = new Date()

      return [start, end]

    }

  },

  {

    text: '本周',

    value: () => {

      const end = new Date()

      const start = new Date()

      start.setDate(start.getDate() - start.getDay() + 1)

      start.setHours(0, 0, 0, 0) // 将时间设置为当天时间的0点

      return [start, end]

    }

  },

  {

    text: '本月',

    value: () => {

      const end = new Date()

      const start = new Date(end.getFullYear(), end.getMonth(), 1) // 这个月1号

      return [start, end]

    }

  }

]

// 年份快捷选项

const shortcuts1 = [

  {

    text: '今年',

    value: [new Date(), new Date()]

  },

  {

    text: '近3年',

    value: () => {

      const end = new Date()

      const start = new Date(

        new Date().setFullYear(new Date().getFullYear() - 2) // 设置开始时间为当前时间前2年(包含当前年)

      )

      return [start, end]

    }

  },

  {

    text: '近5年',

    value: () => {

      const end = new Date()

      const start = new Date(

        new Date().setFullYear(new Date().getFullYear() - 4) // 设置开始时间为当前时间前4年(包含当前年)

      )

      return [start, end]

    }

  }

]

// 初始化设置默认7天日期

const initTime = () => {

  startDate.value = common.formatDate(

    new Date(new Date().getTime() - 6 * 24 * 60 * 60 * 1000),

    'yyyy-MM-dd'

  )

  endDate.value = common.formatDate(new Date(), 'yyyy-MM-dd')

  dateRange.value = [startDate.value, endDate.value]

}

// 控制当前日期之后不能选

const disabledDate = (time: any) => {

  return time.getTime() > new Date().getTime()

}

// 改变日期

const changeDate = (value: any) => {

  if (value) {

    dateRange.value = toRaw(value)

    startDate.value = dateRange.value[0]

    endDate.value = dateRange.value[1]

  } else {

    dateRange.value = toRaw(value)

    startDate.value = ''

    endDate.value = ''

  }

}

// 控制指定年份不能选(可选2019年到当前年)

const disabledYear = (time: any) => {

  const year = time.getFullYear()

  return year < 2019 || year > new Date().getFullYear()

}

// 改变年份

const changeYear = (value: any) => {

  if (value) {

    if (yearPicker.value) {

      yearPicker.value.blur()

    }

        yearRange.value = toRaw(value)

  }

}

// 清空时间

const changeYear1 = () => {

  yearRange.value = []

}

onMounted(() => {

        initTime()

}

</script>

<style lang="less" scoped>

:deep(.el-date-editor) {

        width: 240px;

        height: 32px;

        border-radius: 4px;

        font-size: 12px !important;

      }

</style>

二、common文件方法:

formatDate: function (date: any, format: any) {

    let v = ''

    if (typeof date === 'string' || typeof date !== 'object') {

      return

    }

    const year = date.getFullYear()

    const month = date.getMonth() + 1

    const day = date.getDate()

    const hour = date.getHours()

    const minute = date.getMinutes()

    const second = date.getSeconds()

    const weekDay = date.getDay()

    const ms = date.getMilliseconds()

    let weekDayString = ''

    if (weekDay === 1) {

      weekDayString = '星期一'

    } else if (weekDay === 2) {

      weekDayString = '星期二'

    } else if (weekDay === 3) {

      weekDayString = '星期三'

    } else if (weekDay === 4) {

      weekDayString = '星期四'

    } else if (weekDay === 5) {

      weekDayString = '星期五'

    } else if (weekDay === 6) {

      weekDayString = '星期六'

    } else if (weekDay === 0) {

      weekDayString = '星期日'

    }

    v = format

    // Year

    v = v.replace(/yyyy/g, year)

    v = v.replace(/YYYY/g, year)

    v = v.replace(/yy/g, (year + '').substring(2, 4))

    v = v.replace(/YY/g, (year + '').substring(2, 4))

    // Month

    const monthStr = '0' + month

    v = v.replace(/MM/g, monthStr.substring(monthStr.length - 2))

    // Day

    const dayStr = '0' + day

    v = v.replace(/dd/g, dayStr.substring(dayStr.length - 2))

    // hour

    const hourStr = '0' + hour

    v = v.replace(/HH/g, hourStr.substring(hourStr.length - 2))

    v = v.replace(/hh/g, hourStr.substring(hourStr.length - 2))

    // minute

    const minuteStr = '0' + minute

    v = v.replace(/mm/g, minuteStr.substring(minuteStr.length - 2))

    // Millisecond

    v = v.replace(/sss/g, ms)

    v = v.replace(/SSS/g, ms)

    // second

    const secondStr = '0' + second

    v = v.replace(/ss/g, secondStr.substring(secondStr.length - 2))

    v = v.replace(/SS/g, secondStr.substring(secondStr.length - 2))

    // weekDay

    v = v.replace(/E/g, weekDayString)

    return v

  }

http://www.lryc.cn/news/2393439.html

相关文章:

  • Vue 技术文档
  • 3 分钟学会使用 Puppeteer 将 HTML 转 PDF
  • 速通《Sklearn 与 TensorFlow 机器学习实用指南》
  • Ubuntu 下搭建ESP32 ESP-IDF开发环境,并在windows下用VSCode通过SSH登录Ubuntu开发ESP32应用
  • [FreeRTOS- 野火] - - - 临界段
  • 【洛谷P9303题解】AC代码- [CCC 2023 J5] CCC Word Hunt
  • NodeMediaEdge接入NodeMediaServer
  • 【Java基础-环境搭建-创建项目】IntelliJ IDEA创建Java项目的详细步骤
  • WebSocket指数避让与重连机制
  • DrissionPage WebPage模式:动态交互与高效爬取的完美平衡术
  • adb查看、设置cpu相关信息
  • PHP7+MySQL5.6 查立得源码授权系统DNS验证版
  • 68元开发板,开启智能硬件新篇章——明远智睿SSD2351深度解析
  • 【QQ音乐】sign签名| data参数加密 | AES-GCM加密 | webpack (下)
  • 基于netmiko模块实现支持SSH or Telnet的多线程多厂商网络设备自动化巡检脚本
  • 不用 apt 的解决方案(从源码手动安装 PortAudio)
  • 【前端】JS引擎 v.s. 正则表达式引擎
  • 开发体育平台,怎么接入最合适的数据接口
  • 3D虚拟工厂
  • http传输协议的加密
  • 半导体晶圆制造洁净厂房的微振控制方案-江苏泊苏系统集成有限公司
  • 嵌入式(1):STM32 GPIO与AFIO深度解析:从原理到高阶应用实战
  • Netty 实战篇:Netty RPC 框架整合 Spring Boot,迈向工程化
  • QML视图组件ListView、TableView、GridView介绍
  • 常见压缩算法性能和压缩率对比 LZ4 LZO ZSTD SNAPPY
  • Spring Boot 应用中实现配置文件敏感信息加密解密方案
  • 【TTS】基于GRPO的流匹配文本到语音改进:F5R-TTS
  • 动态规划-152.乘积最大子数组-力扣(LeetCode)
  • 1-1 初探Dart编程语言
  • 搭建最新版开源监控平台SigNoz踩的坑