解决鼠标滚动时element-ui日期选择器错位的问题

解决方案:监听鼠标滚动事件,在鼠标滚动时隐藏element-ui日期选择器下拉框

1、先在util文件夹下创建个hidePicker.js文件,代码如下:

let el = null

const fakeClickOutSide = () => {
  const SELECTWRAP_BODY = document.body // body
  // const SELECTWRAP_DOWNALL = document.querySelectorAll('.el-select-dropdown') // select下拉框
  const SELECTWRAP_TIMEALL = document.querySelectorAll('.el-time-panel') // 时间下拉框
  const SELECTWRAP_DATEALL = document.querySelectorAll('.el-picker-panel') // 日期下拉框
  SELECTWRAP_BODY.click()
  // SELECTWRAP_DOWNALL.forEach((item) => {
  //   item.style.display = 'none'
  // })
  SELECTWRAP_TIMEALL.forEach((item) => {
    item.style.display = 'none'
  })
  SELECTWRAP_DATEALL.forEach((item) => {
    item.style.display = 'none'
  })
  const MousedownEvent = document.createEvent('Events')
  MousedownEvent.initEvent('mousedown', true, true)
  const MouseupEvent = document.createEvent('Events')
  MouseupEvent.initEvent('mouseup', true, true)
  document.dispatchEvent(MousedownEvent)
  document.dispatchEvent(MouseupEvent)

}


const mousedownHandle = e => {
  fakeClickOutSide()
}
const mousewheelHandle = e => {
  fakeClickOutSide()
}
const eventListener = (type) => {
  el[type + 'EventListener']('mousedown', mousedownHandle)
  window[type + 'EventListener']('mousewheel', mousewheelHandle)
  window[type + 'EventListener']('DOMMouseScroll', mousewheelHandle) // fireFox 3.5+
}
export default {
  mounted() {
    el = this.$root.$el
    el.addFakeClickOutSideEventCount = el.addFakeClickOutSideEventCount || 0;
    (!el.addFakeClickOutSideEventCount) && this.$nextTick(() => {
      eventListener('add')
    })
    el.addFakeClickOutSideEventCount += 1
  },
  destroyed() {
    eventListener('remove')
    el.addFakeClickOutSideEventCount -= 1
  }
}


2、在需要使用的页面引入,然后注入到mixins中

import hidePicker from '@/util/hidePicker'

export default {
  mixins: [hidePicker],
  name: "",
  data() {
    return {

    }
  },
  created() {
  },
  mounted() {
    
  },
  methods: {
    
  }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值