问题:

        v-model回显失效,使用el-date-picker组件选择日期后,无法在输入框内回显,检查发现绑定的值确实正确、格式也没有问题,但没有回显内容

        官方文档说明的change事件就是不触发

        有clearable属性控制清空选择内容,但是没有对应的clear事件

解决:

        使用v-bind:value回显,手写事件改变选择日期后对应的值(需要预先声明日期范围对应的属性为数组,对应位置上的值为空串,在事件中使用$set更改

        change事件需要改用input事件

        clear对应也是触发input事件,值为空

template:

<el-date-picker
    :value="filterInsertShow"
    type="daterange"
    unlink-panels
    range-separator="至"
    start-placeholder="开始日期"
    end-placeholder="结束日期"
    :picker-options="pickerOptions"
    clearable
    value-format="yyyy-MM-dd"
    format="yyyy-MM-dd"
    @input="changeInsertShow"
>
</el-date-picker>

script:

data() {
    return {
      //注册日期
      filterInsertShow: ['', ''], 
 
      //快捷日期选中
      pickerOptions: {
        shortcuts: [
          {
            text: '最近一周',
            onClick(picker) {
              const end = new Date();
              const start = new Date();
              start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
              picker.$emit('pick', [start, end]);
            },
          },
          {
            text: '最近一个月',
            onClick(picker) {
              const end = new Date();
              const start = new Date();
              start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
              picker.$emit('pick', [start, end]);
            },
          },
          {
            text: '最近三个月',
            onClick(picker) {
              const end = new Date();
              const start = new Date();
              start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
              picker.$emit('pick', [start, end]);
            },
          },
        ],
      },
    };
  },
methods:{
    changeInsertShow(value) {
      if (value) {
        //设置
        this.$set(this.filterInsertShow, 0, value[0]); //数组的索引响应式需要使用 $set
        this.$set(this.filterInsertShow, 1, value[1]);
      } else {
        //清空
        this.$set(this.filterInsertShow, 0, '');
        this.$set(this.filterInsertShow, 1, '');
      }
    },
}

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐