国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

vue實(shí)現(xiàn)簡(jiǎn)單的鼠標(biāo)拖拽橫向滾動(dòng)和 鼠標(biāo)滾輪橫向滾動(dòng)

這篇具有很好參考價(jià)值的文章主要介紹了vue實(shí)現(xiàn)簡(jiǎn)單的鼠標(biāo)拖拽橫向滾動(dòng)和 鼠標(biāo)滾輪橫向滾動(dòng)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

第一種,按住鼠標(biāo)拖拽滾動(dòng)
以下代碼項(xiàng)目中直接使用即可,此種方法是通過鼠標(biāo)拖拽進(jìn)行滾動(dòng),滑動(dòng)滾輪無效果。
當(dāng)然快捷鍵,shift+鼠標(biāo)滾輪可以控制橫向滾動(dòng),對(duì)用戶來說體驗(yàn)不友好。

<div class="tab-list id="nav">
    <div class="tab-item" v-for="(item,index) in list" :key=""> </div>
</div>

mounted() {
    this.scrollInit();
  },
methods: {
     // 初始化與綁定監(jiān)聽事件方法
    scrollInit() {
      // 獲取要綁定事件的元素
      const nav = document.getElementById("nav")
      var flag; // 鼠標(biāo)按下
      var downX; // 鼠標(biāo)點(diǎn)擊的x下標(biāo)
      var scrollLeft; // 當(dāng)前元素滾動(dòng)條的偏移量
      nav.addEventListener("mousedown", function (event) {
      flag = true;
      downX = event.clientX; // 獲取到點(diǎn)擊的x下標(biāo)
      scrollLeft = this.scrollLeft; // 獲取當(dāng)前元素滾動(dòng)條的偏移量
      });
      nav.addEventListener("mousemove", function (event) {
      if (flag) { // 判斷是否是鼠標(biāo)按下滾動(dòng)元素區(qū)域
      var moveX = event.clientX; // 獲取移動(dòng)的x軸
      var scrollX = moveX - downX; // 當(dāng)前移動(dòng)的x軸下標(biāo)減去剛點(diǎn)擊下去的x軸下標(biāo)得到鼠標(biāo)滑動(dòng)距離
      this.scrollLeft = scrollLeft - scrollX // 鼠標(biāo)按下的滾動(dòng)條偏移量減去當(dāng)前鼠標(biāo)的滑動(dòng)距離
      console.log(scrollX)
      }
      });
      // 鼠標(biāo)抬起停止拖動(dòng)
      nav.addEventListener("mouseup", function () {
      flag = false;
      });
      // 鼠標(biāo)離開元素停止拖動(dòng)
      nav.addEventListener("mouseleave", function (event) {
      flag = false;
      });
    },
  }
};

css代碼

    #nav{
      overflow-x: auto;
      overflow-y: hidden;
    }

第二種方法是通過鼠標(biāo)的滾輪進(jìn)行滾動(dòng)

<div class="tab-list id="nav">
    <div class="tab-item" v-for="(item,index) in list" :key=""> </div>
</div>

mounted() {
    this.scrollInit();
  },
methods: {
     // 初始化與綁定監(jiān)聽事件方法
    scrollInit() {
      // 獲取要綁定事件的元素
      const nav = document.getElementById("nav")
      // document.addEventListener('DOMMouseScroll', handler, false)
      // 添加滾輪滾動(dòng)監(jiān)聽事件,一般是用下面的方法,上面的是火狐的寫法
      nav.addEventListener('mousewheel', handler, false)
      // 滾動(dòng)事件的出來函數(shù)
      function handler(event) {
        // 獲取滾動(dòng)方向
        const detail = event.wheelDelta || event.detail;
        // 定義滾動(dòng)方向,其實(shí)也可以在賦值的時(shí)候?qū)?/span>
        const moveForwardStep = 1;
        const moveBackStep = -1;
        // 定義滾動(dòng)距離
        let step = 0;
        // 判斷滾動(dòng)方向,這里的100可以改,代表滾動(dòng)幅度,也就是說滾動(dòng)幅度是自定義的
        if (detail < 0) {
          step = moveForwardStep * 100;
        } else {
          step = moveBackStep * 100;
        }
        // 對(duì)需要滾動(dòng)的元素進(jìn)行滾動(dòng)操作
        nav.scrollLeft += step;
      }
    },

css代碼文章來源地址http://www.zghlxwxcb.cn/news/detail-507379.html

    #nav{
      overflow-x: auto;
      overflow-y: hidden;
    }

到了這里,關(guān)于vue實(shí)現(xiàn)簡(jiǎn)單的鼠標(biāo)拖拽橫向滾動(dòng)和 鼠標(biāo)滾輪橫向滾動(dòng)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包