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' }
          ],
         
        }
相关推荐
克里斯蒂亚诺更新2 小时前
使用elementUI的表格报错ResizeObserver loop completed with undelivered notifications.
前端·javascript·elementui
C_心欲无痕2 小时前
移动端 B 站弹幕功能实现
前端·javascript
菜鸟很沉2 小时前
Vue 3 组件双向绑定完全指南:update:modelValue 与 defineModel
前端·javascript·vue.js
爱吃香菜i3 小时前
数据连接开发设计文档
前端·javascript
冴羽3 小时前
现代 CSS 颜色使用指南
前端·javascript·css
Rrvive3 小时前
Vue3向全局广播数据变化
javascript·vue.js
han_3 小时前
为啥 Array.isArray 判断数组最靠谱?
前端·javascript
梦6503 小时前
Vue3 计算属性 (computed) 与监听属性 (watch)
前端·javascript·vue.js
六月June June4 小时前
leaflet L.popup().setContent中挂载vue组件
前端·javascript·vue.js