El control de tiempo de elementui limita el rango de tiempo opcional (con precisión de horas, minutos y segundos)

El control de tiempo de elementui limita el rango de tiempo opcional (con precisión de horas, minutos y segundos)

Cuando desarrollamos proyectos web, los controles de tiempo se usan mucho, y restringir el tiempo opcional también es un requisito relativamente común, por ejemplo, no se puede seleccionar el tiempo pasado, o no se puede seleccionar el tiempo futuro, etc. el año, el mes y el día están limitados, es muy fácil de resolver, ¿y si es preciso en la hora, el minuto y el segundo? De hecho, también es muy simple. A continuación, veamos mis requisitos (mi requisito es que la hora pasada no se puede seleccionar y debe ser precisa en hora, minuto y segundo), y el código no tiene mucho que decir:

//我们在vue中的data中定义一个对象,绑定给时间组件
expireTimeOption: {
    
    
   selectableRange:`${
      
      moment().format('HH:mm:SS')} - 23:59:59`,//这里是限制可选时间到时分秒
   //用当前时间减去一整天的时间,得到的就是当前时间到晚上13:59:59的区间
   disabledDate(date) {
    
    //这里是限制可选时间到年月日的
     //disabledDate 文档上:设置禁用状态,参数为当前日期,要求返回 Boolean
     return date.getTime() < Date.now() - 3600 * 1000 * 24;
    },
 },

Pensé que terminaría así. Uno limita el año, el mes, el día y el otro limita la hora, el minuto y el segundo, pero habrá un error. Si son las 8 de la mañana, entonces No puedo elegir antes de las 8 de la mañana. Esto obviamente está mal. Entonces, ¿cómo lo solucionamos? código superior

//使用watch时间监听时间控件的值
watch: {
    
    
    'form.startTime'(selectTime) {
    
    
      const date = moment(selectTime).format('YYYY-MM-DD');
      const today = moment().format('YYYY-MM-DD');
      if (date === today){
    
    //如果选择是日期是当天
         // 先把时间控件的值赋值当前时间
        this.form.startTime = moment().format('YYYY-MM-DD HH:mm:SS')
         //然后限制时间小于此时此刻的时分秒不可选
        this.expireTimeOption.selectableRange = `${
      
      moment().format('HH:mm:SS')} - 23:59:59`
      } else {
    
    //如果选择是日期是明天或者更远的时间
        // 先把时间控件的值赋值为一天的的开始
        this.form.startTime = moment().format('YYYY-MM-DD 00:00:00')
        // 然后把时分秒的限制放开
        this.expireTimeOption.selectableRange = '00:00:00 - 23:59:59'
      }
    },
}

Supongo que te gusta

Origin blog.csdn.net/m0_52313178/article/details/126319525
Recomendado
Clasificación