el-form 表格校验 开始和结束时间,时间选择范围

复制代码
<el-form
        ref="generateForm"
        :model="generateForm"
        :rules="generateRules"
        label-width="120px"
      >
 <el-form-item>
  <template slot="label">
            <span class="required-asterisk">*</span>
            <span>数据周期</span>
          </template>
          <el-col :span="8">
            <el-form-item prop="periodBegin">
              <el-date-picker
                v-model="generateForm.periodBegin"
                type="date"
                style="width: 135px"
                placeholder="开始日期"
                format="yyyy-MM-dd"
                value-format="yyyy-MM-dd"
                :picker-options="datePickerOptions"
              />
            </el-form-item>
          </el-col>
          <el-col class="line" :span="1">-</el-col>
          <el-col :span="8">
            <el-form-item prop="periodEnd">
              <el-date-picker
                v-model="generateForm.periodEnd"
                type="date"
                style="width: 135px"
                placeholder="结束日期"
                format="yyyy-MM-dd"
                value-format="yyyy-MM-dd"
                :picker-options="datePickerOptions"
              />
            </el-form-item>
          </el-col>
          
        </el-form-item>
</el-form>
.required-asterisk {
  color: #f56c6c;
  margin-right: 4px;
}

data() {
    const validatePeriodRangeStart = (rule, value, callback) => {
      
      const begin = this.generateForm.periodBegin;
      const end = this.generateForm.periodEnd;
      if (!begin) return callback(new Error("请选择开始日期"));

      const beginTime = new Date(begin).getTime();
      const endTime = new Date(end).getTime();
      if (Number.isNaN(beginTime)) {
        return callback(new Error("日期格式不正确"));
      }
      if (beginTime > endTime)
        return callback(new Error("开始日期不能晚于结束日期"));

      return callback();
    };
    const validatePeriodRangeEnd = (rule, value, callback) => {
     
      const begin = this.generateForm.periodBegin;
      const end = this.generateForm.periodEnd;
      if (!end) return callback(new Error("请选择结束日期"));

      const beginTime = new Date(begin).getTime();
      const endTime = new Date(end).getTime();
      if (Number.isNaN(endTime)) {
        return callback(new Error("日期格式不正确"));
      }
      if (beginTime > endTime)
        return callback(new Error("开始日期不能晚于结束日期"));

      return callback();
    };
    return {
      loading: false,
      generateForm: {
        statsTime: "",
        periodBegin: "",
        periodEnd: "",
      },
      generateRules: {
        periodBegin: [{ validator: validatePeriodRangeStart, trigger: "change" }],
        periodEnd: [{ validator: validatePeriodRangeEnd, trigger: "change" }],
       
      },
      reportList: [],
      datePickerOptions: {
        disabledDate: (date) => {
          return date && date > new Date();
        },
      },
      monthPickerOptions: {
        disabledDate: (date) => {
          // 仅允许选择"上一个月"及更早的月份
          const now = new Date();
          const lastMonthStart = new Date(
            now.getFullYear(),
            now.getMonth() - 1,
            1
          );
          return date && date.getTime() > lastMonthStart.getTime();
        },
      },
    };
  },

饿了么文档原生案例

复制代码
<el-form-item label="活动时间" required>
    <el-col :span="11">
      <el-form-item prop="date1">
        <el-date-picker type="date" placeholder="选择日期" v-model="ruleForm.date1" style="width: 100%;"></el-date-picker>
      </el-form-item>
    </el-col>
    <el-col class="line" :span="2">-</el-col>
    <el-col :span="11">
      <el-form-item prop="date2">
        <el-time-picker placeholder="选择时间" v-model="ruleForm.date2" style="width: 100%;"></el-time-picker>
      </el-form-item>
    </el-col>
  </el-form-item>

ruleForm: {
          date1: '',
          date2: '',
        },

rules: {
          date1: [
            { type: 'date', required: true, message: '请选择日期', trigger: 'change' }
          ],
          date2: [
            { type: 'date', required: true, message: '请选择时间', trigger: 'change' }
          ],
         
        }
相关推荐
yuezhilangniao8 小时前
AI智能体全栈开发工程化规范 备忘 ~ fastAPI+Next.js
javascript·人工智能·fastapi
~牧马~9 小时前
【记录63】electron打包vue项目之踩坑
vue.js·electron·electron与node兼容
铅笔侠_小龙虾10 小时前
Flutter Demo
开发语言·javascript·flutter
2501_9445255410 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
计算机学姐10 小时前
基于SpringBoot的电影点评交流平台【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·spring·信息可视化·echarts·推荐算法
wangdaoyin201010 小时前
若依vue2前后端分离集成flowable
开发语言·前端·javascript
天天进步201510 小时前
AI Agent 与流式处理:Motia 在生成式 AI 时代的后端范式
javascript
心柠11 小时前
vue3相关知识总结
前端·javascript·vue.js
a11177611 小时前
图书借阅管理系统(FastAPI + Vue)
前端·vue.js·fastapi
常年游走在bug的边缘12 小时前
掌握JavaScript作用域:从函数作用域到块级作用域的演进与实践
开发语言·前端·javascript