iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue的Scroll滚动事件触发方式
  • 687
分享到

Vue的Scroll滚动事件触发方式

2024-04-02 19:04:59 687人浏览 薄情痞子
摘要

目录Scroll滚动事件触发例子监听Scroll事件无效Scroll滚动事件触发 切记 当你需要滚动事件触发 千万不要加 overflow-y: auto; 一旦加了 就 全是 0

Scroll滚动事件触发

切记 当你需要滚动事件触发 千万不要加 overflow-y: auto; 一旦加了 就 全是 0

例子

去掉 overflow-y: auto;

如果你需要把这个页面当做子组件引入 需要加true 因为 ···· 请看最后一张图片 如果不加true 不变成捕获事件 则无法成功引用

<template>
    <div class="totop">
        <div class="btnTop" v-if="btnFlag" @click="backTop()">
            <van-icon name="arrow-up" size="40" color="#CF9B6B" class="imga"/>
        </div>
    </div>
</template>
<script>
export default {
    name: "totop",
    data() {
        return {
            btnFlag: false,
        };
    },
    // 利用Vue写一个在控制台打印当前的scrollTop。首先,在 mounted 钩子中给window添加一个滚动滚动监听事件
    mounted() {
        window.addEventListener("scroll", this.scrollToTop,true);
        //如果你需要把这个页面当做子组件引入 需要加true 因为 ····  请看最后一张图片
    },
    destroyed() {
        window.removeEventListener("scroll", this.scrollToTop,true);
    },
    methods: {
        // 点击图片回到顶部方法,加计时器是为了过渡顺滑
        backTop() {
            let that = this;
            let timer = setInterval(() => {
                let ispeed = Math.floor(-that.scrollTop / 5);
                document.documentElement.scrollTop = document.body.scrollTop =
                        that.scrollTop + ispeed;
                if (that.scrollTop === 0) {
                    clearInterval(timer);
                }
            }, 16);
        },
        // 监听回到顶部按钮距浏览器顶部的距离,滚动的距离如果大于浏览器高度时,设置 btnFlag 为true,否则就是false
        scrollToTop() {
            let that = this;
            let scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop;
            that.scrollTop = scrollTop;
            console.log(scrollTop)
            //为了计算距离顶部的高度,当高度大于50显示回顶部图标,小于50则隐藏
            if (that.scrollTop > 50) {
                that.btnFlag = true;
            } else {
                that.btnFlag = false;
            }
        },
    },
};
</script>
<style lang="sCSS" scoped>
.totop {
    position: fixed;
    right: 40px;
    bottom: 60px;
    width: 50px;
    height: 50px;
    padding: 10px;
    cursor: pointer;
}
.imga {
    position: relative;
    top: -20px;
    left: 15px;
    text-align: center;
    line-height: 50px;
    border: 3px solid #CF9B6B;
    width: 50px;
    height: 50px;
    border-radius: 50%;
}
</style>

监听Scroll事件无效

1.监听的dom元素设定高度,子元素的内容要超过容器的高度

2.设定overflow为:auto/scroll,默认值为visible,无法触发

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: Vue的Scroll滚动事件触发方式

本文链接: https://www.lsjlt.com/news/147028.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Vue的Scroll滚动事件触发方式
    目录Scroll滚动事件触发例子监听Scroll事件无效Scroll滚动事件触发 切记 当你需要滚动事件触发 千万不要加 overflow-y: auto; 一旦加了 就 全是 0 ...
    99+
    2024-04-02
  • Vue的Scroll滚动事件触发方式是什么
    这篇文章主要介绍了Vue的Scroll滚动事件触发方式是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue的Scroll滚动事件触发方式是什么文章都会有所收获,下面我们一起来看看吧。Scroll滚动事件触...
    99+
    2023-06-30
  • Vue手动控制点击事件Click触发方式
    目录手动控制点击事件Click触发方法一方法二Vue点击click事件解析废话不多说,先上代码手动控制点击事件Click触发 方法一 变量的值&&触发函数 方法二 ...
    99+
    2024-04-02
  • vue如何自动触发事件
    在vue中设置自动触发事件的方法:1.新建vue.js项目;2.添加button按钮,使用@click属性绑定事件;3.使用directives属性设置事件自动触发;具体步骤如下:首先,在vue-cli中创建一个vue.js项目;vue c...
    99+
    2024-04-02
  • vue如何手动触发事件
    在vue中手动触发事件的方法:1.新建vue.js项目;2.使用@click.native属性绑定事件;3.添加button按钮;4.添加代码设置手动触发;具体步骤如下:首先,在vue-cli中创建一个vue.js项目;vue create...
    99+
    2024-04-02
  • vue中的主动触发点击事件
    目录主动触发点击事件如何自动触发点击事件模拟点击下载文件、图片主动触发点击事件 由vue代码触发点击事件,实现的效果是:点击按钮,触发 <input> 输入框点击事件,从...
    99+
    2024-04-02
  • vue怎么监听页面滚动到某个高度触发事件
    本篇内容主要讲解“vue怎么监听页面滚动到某个高度触发事件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue怎么监听页面滚动到某个高度触发事件”吧!监听页面滚动到某个高度触发事件methods...
    99+
    2023-06-30
  • vue监听页面滚动到某个高度触发事件流程
    目录监听页面滚动到某个高度触发事件动态监听页面滚动高度监听页面滚动到某个高度触发事件 methods: {    showIcon() {       if (         !!...
    99+
    2024-04-02
  • vue-seamless-scroll无缝滚动组件使用方法详解
    本文实例为大家分享了vue无缝滚动组件vue-seamless-scroll的具体实现代码,供大家参考,具体内容如下 下载 cnpm i -S vue-seamless-scrol...
    99+
    2024-04-02
  • 无限滚动插件vue-infinite-scroll的示例分析
    小编给大家分享一下无限滚动插件vue-infinite-scroll的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!插件...
    99+
    2024-04-02
  • vue-seamless-scroll无缝滚动组件怎么使用
    今天小编给大家分享一下vue-seamless-scroll无缝滚动组件怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧...
    99+
    2023-06-29
  • vue中如何实现无缝滚动组件vue-seamless-scroll
    小编给大家分享一下vue中如何实现无缝滚动组件vue-seamless-scroll,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧...
    99+
    2024-04-02
  • vue如何触发change事件
    在vue中触发change事件的方法:1.新建vue.js项目;2.使用v-model指令绑定change事件;3.调用setData方法触发change事件;具体步骤如下:首先,在vue-cli中创建一个vue.js项目;vue crea...
    99+
    2024-04-02
  • vue中如何实现移动端的scroll滚动
    这篇文章主要为大家展示了“vue中如何实现移动端的scroll滚动”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue中如何实现移动端的scroll滚动”这篇文...
    99+
    2024-04-02
  • vue开发移动端使用better-scroll时click事件失效的解决方案
    最近使用vue学习开发移动端的项目,使用了better-scroll插件做滚动。 在引入better-scroll的组件中使用@click事件的时候,点击事件失效,v-on:clic...
    99+
    2024-04-02
  • vue使用better-scroll实现横向滚动的方法实例
    一、滚动的实现原理 better-scroll的滚动原理和浏览器原生滚动原理是一样的,当子盒子的高度大于父盒子的高度,就会出现纵向滚动;同理,如果子盒子的宽度大于父盒子的宽度,那么...
    99+
    2024-04-02
  • Vue中父子组件通信与事件触发的方法
    这篇文章主要讲解了“Vue中父子组件通信与事件触发的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue中父子组件通信与事件触发的方法”吧!一、组件子组件<template>...
    99+
    2023-06-29
  • 微信小程序组件scroll-view滚动到底部多次触发加载如何解决?
    在 iOS 真机上,scroll-view 滚动时会多次触发 scrolltolower 事件的问题,可以设置一个“加载标识”(如 DisableTrigger)来避免重复请求下一页数据。具体做法为:...
    99+
    2023-09-06
    小程序
  • vue监听滚动事件如何实现滚动监听
    这篇文章主要为大家展示了“vue监听滚动事件如何实现滚动监听”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue监听滚动事件如何实现滚动监听”这篇文章吧。在vu...
    99+
    2024-04-02
  • vue怎么再进页面自动触发单击事件
    在 Vue 中,我们可以通过 v-on 指令或 @ 符号来绑定事件。但是,如何在页面进入时自动触发单击事件呢?下面将介绍两种方案来实现该功能。方案一:使用 mounted 钩子函数mounted 钩子函数是 Vue 生命周期中的一个阶段,表...
    99+
    2023-05-24
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作