使用 Element+vue实现开始时间结束时间限制

html部分: 

 

js部分:

data() {
            return {
                pickerOptionsStart: {},
                pickerOptionsEnd: {},
                startDate: '', // 开始日期
                endDate: '', // 结束日期
                }
}



methods: {
           
            changeStart() { // 限制开始时间
                this.pickerOptionsEnd = Object.assign({}, this.pickerOptionsEnd, {
                    disabledDate: (time) => {
                        if (this.startDate) {
                            return time.getTime() < this.startDate
                        }
                    }
                })
            },

            changeEnd() { // 限制结束时间
                console.log(this.endDate);
                this.pickerOptionsStart = Object.assign({}, this.pickerOptionsStart, {
                    disabledDate: (time) => {
                        if (this.endDate) {
                            return time.getTime() > this.endDate
                        }
                    }
                })
            },

            beautifyTimeFormat(value) { // 时间戳转换时间格式
                if (value == null) {
                    return '';
                } else {
                    let date = new Date(value);
                    let y = date.getFullYear();// 年
                    let MM = date.getMonth() + 1;// 月
                    MM = MM < 10 ? ('0' + MM) : MM;
                    let d = date.getDate();// 日
                    d = d < 10 ? ('0' + d) : d;
                    return y + '-' + MM + '-' + d;
                }
            }
}

 

 

html写法2

 



js部分:

var Main = {
    data() {
      return {
        pickerOptionsStart: {},
        pickerOptionsEnd:{},
        startDate: '',
        endDate: '',
      };
    },
    methods:{
      changeStart (){
      	this.pickerOptionsStart = Object.assign({},this.pickerOptionsStart,{
          disabledDate: (time) => {
            return time.getTime() > this.endDate
          }
        })
      },
      changeEnd (){
      	this.pickerOptionsEnd = Object.assign({},this.pickerOptionsEnd,{
          disabledDate: (time) => {
          	return time.getTime() < this.startDate
        	}
        })
      }
    }
  };
var Ctor = Vue.extend(Main)
new Ctor().$mount('#app')

 

 

css部分:

@import url("//unpkg.com/[email protected]/lib/theme-chalk/index.css");

.block{
  margin-top:10px;
}

 

你可能感兴趣的:(vue)