vue的element-ui中有个日期时间选择器,有个需求就是只需要使用选择器,而不需要输入框,也就是说选择时间的触发条件是别的事件,比如点击某个按钮。

 

实现效果:

组件默认样式:输入框和时间选择器是绑定的,当点击输入框时,才显示时间选择器。

antdesign vue日期时间选择组件选择日期实现界面显示 vue弹出框日期选择器_选择器

 

需求:当点击选项:自定义时间 时,显示出时间选择器,此时可以选择时间。

antdesign vue日期时间选择组件选择日期实现界面显示 vue弹出框日期选择器_选择器_02

      

antdesign vue日期时间选择组件选择日期实现界面显示 vue弹出框日期选择器_输入框_03

 

 实现代码:

1.template:

<!-- 时间选择器 -->
<el-date-picker
  v-model="form.timeValueArr"
  type="datetimerange"
  range-separator="至"
  start-placeholder="开始日期"
  end-placeholder="结束日期"
  value-format="yyyy-MM-dd HH:mm:ss"
  ref="datePickerRef"
  v-show="false"
  @change="fnchooseCustomTime"
>
</el-date-picker>

2.js:

this.$refs.datePickerRef.$el.click(); // 手动控制日期时间选择器打开

// 选择自定义时间范围
fnchooseCustomTime(value) {
  this.form.timeValue = value.join(",");
  this.chooseTime();
},

 

实现原理:

1.需要在HTML中添加一个日期时间选择器,但是设置为false,不显示。

2.给它设置一个ref标识,在需要选择自定义时间时,直接通过this.$refs.datePickerRef找到该组件,然后$el表示组件元素,通过调用click点击事件控制选择器显示。

3.给组件设置change方法,当选择完时间之后,可以获取到选择的时间,进行需要的操作。

 

bug:

上面处理出现的bug就是时间选择器会跑到页面左上角,因为时间选择器是相对选择框来定位的,当选择框设置隐藏时,时间选择器就会相对整个页面来定位了,elementui封装的就是如此,除非修改源码。

所以还是需要让选择框显示,不能设置隐藏,但是可以通过设置层级间接实现。

 

解决代码:

1.template:

<!-- 时间选择器 -->
<el-date-picker
  v-model="form.timeValueArr"
  type="datetimerange"
  range-separator="至"
  start-placeholder="开始日期"
  end-placeholder="结束日期"
  value-format="yyyy-MM-dd HH:mm:ss"
  ref="datePickerRef"
  class="date_style"
  @change="fnchooseCustomTime"
>
</el-date-picker>

2.js不变,同上。

3.css:

.date_style {
  margin-left: -100px;
  width: 100px;
  z-index: -1;
}

 

注意:

1.由于在element-UI中对组件进行了封装,所以将输入框和选择器绑定到了一起,只对外提供了一个标签来使用,所以我们这边很难做修改,需要改变源代码。但是可以采用巧妙的办法:比如通过手动的方法来控制组件实现效果。

2.只要清楚了组件实现的原理,任何组件都可以实现所有想要的效果。