vue 报告标题时间来自 elementUI的 el-date-picker 有开始时间和结束时间

要在Vue中使用 Element UI 的 el-date-picker 来选择开始时间和结束时间,并将其展示在报告中,以下是详细的实现步骤。

实现思路:

  1. 使用 Element UI 的 el-date-picker 组件,让用户选择时间范围(开始时间和结束时间)。
  2. 将选择的时间显示在报告的时间区域。
  3. 根据选择的时间范围格式化显示。
  4. 提供默认格式化,也可以根据需要自定义显示格式。

实现代码:

vue 复制代码
<template>
  <div class="report-container">
    <!-- 标题 -->
    <h1 class="report-title">用户安防报告</h1>

    <!-- 时间选择器 -->
    <div class="date-picker">
      <el-date-picker
        v-model="dateRange"
        type="daterange"
        range-separator="至"
        start-placeholder="开始日期"
        end-placeholder="结束日期"
        @change="onDateChange"
        format="yyyy-MM-dd HH:mm:ss"
        value-format="yyyy-MM-dd HH:mm:ss"
      >
      </el-date-picker>
    </div>

    <!-- 显示选择的时间范围 -->
    <p v-if="formattedDateRange" class="report-time">
      报告时间:{{ formattedDateRange }}
    </p>

    <!-- 正文部分(可根据需要填写内容) -->
    <div class="report-body">
      <p>安防报告的具体内容展示区域。</p>
    </div>
  </div>
</template>

<script>
import { format } from "date-fns"; // 可选:使用 date-fns 格式化日期

export default {
  data() {
    return {
      dateRange: null, // 存储用户选择的时间范围
      formattedDateRange: "", // 存储格式化后的时间范围
    };
  },
  methods: {
    onDateChange(value) {
      // 当用户选择时间范围时触发
      if (value) {
        const [startDate, endDate] = value;
        // 格式化时间范围
        this.formattedDateRange = `${this.formatDate(startDate)} 至 ${this.formatDate(endDate)}`;
      } else {
        this.formattedDateRange = "";
      }
    },
    formatDate(date) {
      // 自定义时间格式化,可根据需要调整
      return format(new Date(date), "yyyy-MM-dd HH:mm:ss");
    }
  }
};
</script>

<style scoped>
/* 容器样式 */
.report-container {
  max-width: 800px;
  margin: 0 auto;
  padding: 20px;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  background-color: #f9f9f9;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  font-family: 'Arial', sans-serif;
}

/* 标题样式 */
.report-title {
  font-size: 28px;
  font-weight: bold;
  color: #333;
  margin-bottom: 10px;
  text-align: center;
}

/* 时间选择器样式 */
.date-picker {
  margin-bottom: 20px;
  text-align: center;
}

/* 时间样式 */
.report-time {
  font-size: 14px;
  color: #666;
  text-align: center;
  margin-bottom: 20px;
}

/* 正文样式 */
.report-body {
  font-size: 16px;
  line-height: 1.6;
  color: #444;
  padding: 10px 0;
}
</style>

关键点:

  1. 使用 el-date-picker 选择时间范围:

    • v-model="dateRange":绑定选择的时间范围。
    • type="daterange":选择日期范围。
    • @change 事件:在用户选择时间后,调用 onDateChange 方法格式化时间并显示。
  2. 格式化时间:

    • 使用 date-fns 库(可选)来格式化时间,也可以使用原生的 Date 对象进行格式化。
    • 将格式化后的时间范围显示在 formattedDateRange 中,并展示在页面上。
  3. 样式设计:

    • 美化 el-date-picker 和时间显示部分,使其与报告的整体风格一致。

依赖:

  • Element UI 需要先安装并引入 Element UI 库:

    bash 复制代码
    npm install element-ui

    然后在项目中引入:

    javascript 复制代码
    import ElementUI from 'element-ui';
    import 'element-ui/lib/theme-chalk/index.css';
    Vue.use(ElementUI);
  • date-fns(可选):

    bash 复制代码
    npm install date-fns

小结:

  • 用户可以通过日期选择器选择开始时间和结束时间,并动态显示在页面上。
  • 通过 el-date-picker@change 事件捕获用户选择的时间,并格式化为所需的显示格式。

下一步建议:

a. 为报告内容增加打印功能,生成PDF或打印。
b. 增加校验,确保用户选择的时间范围有效。

相关推荐
●VON23 分钟前
使用 Electron 构建天气桌面小工具:调用公开 API 实现跨平台实时天气查询V1.0.0
前端·javascript·electron·openharmony
穷人小水滴1 小时前
使用 epub 在手机快乐阅读
javascript·deno·科幻
爱学习的程序媛3 小时前
《深入浅出Node.js》核心知识点梳理
javascript·node.js
华仔啊3 小时前
Vue3 如何实现图片懒加载?其实一个 Intersection Observer 就搞定了
前端·vue.js
Robet4 小时前
TS和JS成员变量修饰符
javascript·typescript
方法重载4 小时前
前端性能优化之“代码分割与懒加载”)
javascript
我叫张小白。4 小时前
Vue3 响应式数据:让数据拥有“生命力“
前端·javascript·vue.js·vue3
laocooon5238578864 小时前
vue3 本文实现了一个Vue3折叠面板组件
开发语言·前端·javascript
科普瑞传感仪器4 小时前
从轴孔装配到屏幕贴合:六维力感知的机器人柔性对位应用详解
前端·javascript·数据库·人工智能·机器人·自动化·无人机
n***F8755 小时前
SpringMVC 请求参数接收
前端·javascript·算法