vue自定义指令 鼠标滚轮控制元素的x轴

vue 鼠标滚轮控制元素的x轴

使用directive,自定义指令

// directive/xScroll/index.js
function xWheel(event) {
  event.preventDefault()
  this.scrollLeft += event.deltaY > 0 ? 20 : -20 // 这里的参数控制滚轮的速度
}
export default {
  mounted(el) {
    el.addEventListener('wheel', xWheel)
  },
  beforeUnmount(el) {
    el.removeEventListener('whell', xWheel)
  }
}
// directive/index.js
import xScroll from './xScroll'

const directives = {
  xScroll // 鼠标滚轮控制x轴
}

export default {
  install(app) {
    Object.keys(directives).forEach((key) => {
      app.directive(key, directives[key])
    })
  }
}

使用

// main.js
import { createApp } from 'vue'
import App from './App.vue'
import directive from './directive/index.js'
const app = createApp(App)
app.use(directive)
app.mount('#app')
<div v-xScroll>...</div>
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值