欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue頁面中實(shí)現(xiàn)平滑滾動(dòng)功能

 更新時(shí)間:2023年12月03日 10:34:43   作者:種花的人_  
這是一個(gè)實(shí)現(xiàn)平滑滾動(dòng)的函數(shù),可以讓頁面在滾動(dòng)到指定位置時(shí)產(chǎn)生緩動(dòng)效果,本文給大家介紹了如何在在Vue頁面中實(shí)現(xiàn)平滑滾動(dòng)功能,<BR>,文中詳細(xì)的代碼講解供大家參考,具有一定的參考價(jià)值,需要的朋友可以參考下

這是一個(gè)實(shí)現(xiàn)平滑滾動(dòng)的函數(shù),可以讓頁面在滾動(dòng)到指定位置時(shí)產(chǎn)生緩動(dòng)效果

該函數(shù)依賴于Math.easeInOutQuad函數(shù)和requestAnimFrame函數(shù),其中Math.easeInOutQuad函數(shù)用于計(jì)算當(dāng)前滾動(dòng)位置的值(根據(jù)時(shí)間、起始值、變化量和持續(xù)時(shí)間),requestAnimFrame函數(shù)用于實(shí)現(xiàn)動(dòng)畫效果。

函數(shù)的參數(shù)包括:

  • to: 目標(biāo)滾動(dòng)位置;
  • duration: 滾動(dòng)持續(xù)時(shí)間,默認(rèn)為500毫秒;
  • callback: 滾動(dòng)結(jié)束后的回調(diào)函數(shù)。

函數(shù)的實(shí)現(xiàn)過程如下:

  • 獲取當(dāng)前滾動(dòng)位置(start)和需要滾動(dòng)的距離(change);
  • 設(shè)置每次滾動(dòng)的增量(increment),默認(rèn)為20;
  • 定義動(dòng)畫開始時(shí)間(currentTime),默認(rèn)為0;
  • 根據(jù)Math.easeInOutQuad函數(shù)計(jì)算新的滾動(dòng)位置值,并將其應(yīng)用于文檔的scrollTop屬性;
  • 判斷當(dāng)前時(shí)間是否小于持續(xù)時(shí)間,如果是則使用requestAnimFrame函數(shù)繼續(xù)執(zhí)行動(dòng)畫,否則執(zhí)行回調(diào)函數(shù)。
Math.easeInOutQuad = function(t, b, c, d) {
  t /= d / 2
  if (t < 1) {
    return c / 2 * t * t + b
  }
  t--
  return -c / 2 * (t * (t - 2) - 1) + b
}
 
var requestAnimFrame = (function() {
  return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || function(callback) { window.setTimeout(callback, 1000 / 60) }
})()
 
/**
 * @param {number} amount
 */
function move(amount) {
  document.documentElement.scrollTop = amount
  document.body.parentNode.scrollTop = amount
  document.body.scrollTop = amount
}
 
function position() {
  return document.documentElement.scrollTop || document.body.parentNode.scrollTop || document.body.scrollTop
}
 
/**
 * @param {number} to
 * @param {number} duration
 * @param {Function} callback
 */
export function scrollTo(to, duration, callback) {
  const start = position()
  const change = to - start
  const increment = 20
  let currentTime = 0
  duration = (typeof (duration) === 'undefined') ? 500 : duration
  var animateScroll = function() {
    // increment the time
    currentTime += increment
    // find the value with the quadratic in-out easing function
    var val = Math.easeInOutQuad(currentTime, start, change, duration)
    // move the document.body
    move(val)
    // do the animation unless its over
    if (currentTime < duration) {
      requestAnimFrame(animateScroll)
    } else {
      if (callback && typeof (callback) === 'function') {
        // the animation is done so lets callback
        callback()
      }
    }
  }
  animateScroll()
}

要使用這個(gè)平滑滾動(dòng)的功能,你需要按照以下步驟進(jìn)行操作:

  • 將上述代碼復(fù)制到你的項(xiàng)目中的一個(gè)文件中(比如scroll.js),并確保該文件被引入到你的Vue組件中。

  • 在你的Vue組件中,可以通過以下方式調(diào)用scrollTo函數(shù):

import { scrollTo } from './scroll.js';
 
export default {
  methods: {
    smoothScroll() {
      scrollTo(0, 1000, () => {
        console.log('滾動(dòng)結(jié)束!');
      });
    }
  },
};

在上面的例子中,我們將scrollTo函數(shù)封裝在Vue組件的methods選項(xiàng)中的smoothScroll方法中。當(dāng)你希望觸發(fā)平滑滾動(dòng)時(shí),可以在模板或其他方法中調(diào)用這個(gè)方法。

在Vue組件的模板中,你可以綁定按鈕的點(diǎn)擊事件來觸發(fā)平滑滾動(dòng)。例如:

<template>
  <div>
    <button @click="smoothScroll">平滑滾動(dòng)到頂部</button>
  </div>
</template>

在上面的例子中,當(dāng)按鈕被點(diǎn)擊時(shí),會(huì)調(diào)用smoothScroll方法,從而觸發(fā)平滑滾動(dòng)。

確保根據(jù)你的實(shí)際需求修改代碼中的目標(biāo)滾動(dòng)位置、持續(xù)時(shí)間和回調(diào)函數(shù)等參數(shù)。

以上就是Vue頁面中實(shí)現(xiàn)平滑滾動(dòng)的效果的詳細(xì)內(nèi)容,更多關(guān)于Vue頁面平滑滾動(dòng)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue中使用element ui的彈窗與echarts之間的問題詳解

    vue中使用element ui的彈窗與echarts之間的問題詳解

    這篇文章主要介紹了vue中使用element ui的彈窗與echarts之間的問題詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Vue.js組件使用props傳遞數(shù)據(jù)的方法

    Vue.js組件使用props傳遞數(shù)據(jù)的方法

    這篇文章主要為大家詳細(xì)介紹了Vue.js組件使用props傳遞數(shù)據(jù)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • vue同一個(gè)瀏覽器登錄不同賬號(hào)數(shù)據(jù)覆蓋問題解決方案

    vue同一個(gè)瀏覽器登錄不同賬號(hào)數(shù)據(jù)覆蓋問題解決方案

    同一個(gè)瀏覽器登錄不同賬號(hào)session一致,這就導(dǎo)致后面登錄的用戶數(shù)據(jù)會(huì)把前面登錄的用戶數(shù)據(jù)覆蓋掉,這個(gè)問題很常見,當(dāng)前我這邊解決的就是同一個(gè)瀏覽器不同窗口只能登錄一個(gè)用戶,對(duì)vue同一個(gè)瀏覽器登錄不同賬號(hào)數(shù)據(jù)覆蓋問題解決方法感興趣的朋友一起看看吧
    2024-01-01
  • VUE組件中的 Drawer 抽屜實(shí)現(xiàn)代碼

    VUE組件中的 Drawer 抽屜實(shí)現(xiàn)代碼

    這篇文章主要介紹了VUE組件 之 Drawer 抽屜 ,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-08-08
  • 圖文講解vue的v-if使用方法

    圖文講解vue的v-if使用方法

    在本篇文章里我們給大家分享了關(guān)于vue的v-if使用方法的相關(guān)知識(shí)點(diǎn),有興趣的朋友們跟著學(xué)習(xí)下。
    2019-02-02
  • vue使用jsMind思維導(dǎo)圖的實(shí)戰(zhàn)指南

    vue使用jsMind思維導(dǎo)圖的實(shí)戰(zhàn)指南

    jsMind是一個(gè)顯示/編輯思維導(dǎo)圖的純javascript類庫,其基于 html5的canvas進(jìn)行設(shè)計(jì),這篇文章主要給大家介紹了關(guān)于vue使用jsMind思維導(dǎo)圖的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • 通過npm引用的vue組件使用詳解

    通過npm引用的vue組件使用詳解

    本文章通過實(shí)現(xiàn)一個(gè)vue-dialog的彈出層組件,然后附加說明如果發(fā)布此包到npm,且能被其他項(xiàng)目使用。本文給大家介紹的非常詳細(xì),需要的的朋友參考下
    2017-03-03
  • Vue實(shí)現(xiàn)動(dòng)態(tài)創(chuàng)建和刪除數(shù)據(jù)的方法

    Vue實(shí)現(xiàn)動(dòng)態(tài)創(chuàng)建和刪除數(shù)據(jù)的方法

    下面小編就為大家分享一篇Vue實(shí)現(xiàn)動(dòng)態(tài)創(chuàng)建和刪除數(shù)據(jù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • 詳解Vue?自定義hook?函數(shù)

    詳解Vue?自定義hook?函數(shù)

    這篇文章主要介紹了詳解Vue自定義hook函數(shù),hook函數(shù)本質(zhì)是一個(gè)函數(shù),把setup函數(shù)中使用的Composition?API進(jìn)行了封裝,更多相關(guān)內(nèi)容感興趣的朋友可以參考一下
    2022-06-06
  • vue實(shí)現(xiàn)table表格里面數(shù)組多層嵌套取值

    vue實(shí)現(xiàn)table表格里面數(shù)組多層嵌套取值

    這篇文章主要介紹了vue實(shí)現(xiàn)table表格里面數(shù)組多層嵌套取值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評(píng)論