element-ui 组件DateTimePicker使用(选择今天及以后的范围+开始和结束时间分开传给后台+回显+编辑页面改变回显问题)

vue文件

html

<el-form-item class="" label="活动时间:" prop="activityTime">
  <el-date-picker
    v-model="activityForm.activityTime"
    type="datetimerange"
    @change="timeChange"
    value-format="yyyy-MM-dd HH:mm:ss"
    :clearable="false"
    range-separator="至"
    start-placeholder="开始日期"
    end-placeholder="结束日期">
  </el-date-picker>
</el-form-item>

data

//return
activityForm: {
	activityTime: [],
},
//校验
rules: {
	activityTime: [
	   { required: true, message: '请选择活动时间', trigger: 'change' }
	 ],
},
//时间范围控制
pickerOptions: {
  disabledDate (time) {
    return time.getTime() < Date.now() - 1 * 24 * 3600 * 1000 // 选当前时间前一天之后的时间
   // return time.getTime() > Date.now() // 选当前时间之前的时间
  }
},

methods

//时间改变
timeChange (val) {
	 var st = new Date(val) * 1000 / 1000
	 if (st < Date.now()) {
	   this.activityForm.activityTime = new Date()
	 }
},

开始和结束时间分开传给后台

建立一个js文件放入下面的代码
// arrayUtil.js
/**
 * @description 安全的获取数组对应下标数据
 * @param { Array } arr
 * @param { int } index
 */
export const saveGet = (arr, index) => {
  return arr[index];
  // if( arr & Array.isArray(arr)) {
  //   return arr[index];
  // } else {
  //   return undefined;
  // }
}

在vue页面引入
import { saveGet } from '../../assets/js/array;
传值
'start_time': saveGet(self.activityForm.activityTime, 0),
 'end_time': saveGet(self.activityForm.activityTime, 1),

后台分开给两个时间,存入数组回显

let getTimeArr = new Array()
getTimeArr.push(data.result.start_time)
getTimeArr.push(data.result.end_time)
this.activityForm.activityTime = getTimeArr

编辑页面改变时间回显问题

@change改成@input
<el-form-item class="" label="活动时间:" prop="activityTime">
  <el-date-picker
    v-model="activityForm.activityTime"
    type="datetimerange"
    @input="timeEditChange"
    value-format="yyyy-MM-dd HH:mm:ss"
    :clearable="false"
    range-separator="至"
    start-placeholder="开始日期"
    end-placeholder="结束日期">
  </el-date-picker>
</el-form-item>
//时间改变
timeEditChange (val) {
	Vue.set(this.activityForm,   'activityForm ', [ val] )
},
借鉴

https://www.cnblogs.com/dhui/p/13322290.html

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值