我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何使用Vue代码实现一个上下滚动加载组件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何使用Vue代码实现一个上下滚动加载组件

本篇内容主要讲解“如何使用Vue代码实现一个上下滚动加载组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Vue代码实现一个上下滚动加载组件”吧!

组件代码

// scrollLoader.vue// 滚动加载组件<style scoped>  .container-main {margin: 0 auto; overflow: auto; overflow-x: hidden; padding: 0;}  .loading{ width: 100%; height: 40px; position: relative; overflow: hidden; text-align: center; margin: 5px 0 ; color: #999; font-size: 13px;}  .loading-icon{color: #707070;};  .loader {    font-size: 10px;    margin: 8px auto;    text-indent: -9999em;    width: 24px;    height: 24px;    border-radius: 50%;    background: #999;    background: -moz-linear-gradient(left, #999 10%, rgba(255, 255, 255, 0) 42%);    background: -webkit-linear-gradient(left, #999 10%, rgba(255, 255, 255, 0) 42%);    background: -o-linear-gradient(left, #999 10%, rgba(255, 255, 255, 0) 42%);    background: -ms-linear-gradient(left, #999 10%, rgba(255, 255, 255, 0) 42%);    background: linear-gradient(to right, #999 10%, rgba(255, 255, 255, 0) 42%);    position: relative;    -webkit-animation: load3 1s infinite linear;    animation: load3 1s infinite linear;  }  .loader:before {    width: 50%;    height: 50%;    background: #999;    border-radius: 100% 0 0 0;    position: absolute;    top: 0;    left: 0;    content: '';  }  .loader:after {    background: #f5f5f5;    width: 72%;    height: 75%;    border-radius: 68%;    content: '';    margin: auto;    position: absolute;    top: 0;    left: 0;    bottom: 0;    right: 0;  }  @-webkit-keyframes load3 {  0% {    -webkit-transform: rotate(0deg);    transform: rotate(0deg);  }  100% {    -webkit-transform: rotate(360deg);    transform: rotate(360deg);  }  }  @keyframes load3 {  0% {    -webkit-transform: rotate(0deg);    transform: rotate(0deg);  }  100% {    -webkit-transform: rotate(360deg);    transform: rotate(360deg);  }  }</style><template>  <div id="scrollLoader-container" class="container-main">    <div class="loading" v-if="topLoading">      <div class="loader">加载中...</div>    </div>    <div :>      <slot></slot>    </div>    <div class="loading" v-if="bottonLoading">      <div class="loader">加载中...</div>    </div>  </div></template><script>  export default {    name: "scroll-loader",    props: {      //给slot传一个最小值,保证一开始能出现滚动条      'minHeight': {        type: Number,        default: 800      },     },    created(){    },    computed: {      realMinHeight(){        return this.minHeight + 30      }    },    data() {      return {        topLoading: false,        bottonLoading: false,        stopTopLoading: false, //是否停止传播滚动到顶部事件        stopBottonLoading: false, //是否停止传播滚动到底部事件      }    },    mounted(){      this.listenScroll();    },    methods: {      listenScroll(){        var me = this;        var topDone = (stopTopLoading) => {          me.topLoading = false;          if(stopTopLoading) me.stopTopLoading = true;        };        var bottonDone = (stopBottonLoading) => {          me.bottonLoading = false;          if(stopBottonLoading) me.stopBottonLoading = true;        };        setTimeout(function(){          var scrollContainer = document.getElementById('scrollLoader-container');          scrollContainer.onscroll = function(){            if(scrollContainer.scrollTop<=0 && !me.stopTopLoading){              if(me.topLoading) return;              me.topLoading = true;              me.$emit('scroll-to-top', topDone);            }            if((scrollContainer.offsetHeight + scrollContainer.scrollTop+1 >= scrollContainer.scrollHeight) && !me.stopBottonLoading){              if(me.bottonLoading) return;              me.bottonLoading = true;              scrollContainer.scrollTop += 40;              me.$emit('scroll-to-botton', bottonDone);            }          }        }, 50)      },    }  }</script>

vue是什么

Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。

到此,相信大家对“如何使用Vue代码实现一个上下滚动加载组件”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何使用Vue代码实现一个上下滚动加载组件

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

下载Word文档

猜你喜欢

如何使用Vue代码实现一个上下滚动加载组件

本篇内容主要讲解“如何使用Vue代码实现一个上下滚动加载组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Vue代码实现一个上下滚动加载组件”吧!组件代码// scrollLoader.
2023-07-04

如何使用Vue代码实现一个分页组件

本篇内容主要讲解“如何使用Vue代码实现一个分页组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Vue代码实现一个分页组件”吧!组件部分代码:Vue.component(zpagena
2023-07-04

如何使用vue代码实现虚拟滚动

这篇“如何使用vue代码实现虚拟滚动”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何使用vue代码实现虚拟滚动”文章吧。滚
2023-07-04

如何使用vue实现一个toast弹窗组件

本篇内容介绍了“如何使用vue实现一个toast弹窗组件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先,我们来分析一下弹窗组件的特性(需
2023-07-04

vue如何使用递归组件实现一个树形控件

这篇文章主要介绍“vue如何使用递归组件实现一个树形控件”,在日常操作中,相信很多人在vue如何使用递归组件实现一个树形控件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue如何使用递归组件实现一个树形控件
2023-07-04

利用SpringMVC如何实现一个文件上传下载功能

这篇文章给大家介绍利用SpringMVC如何实现一个文件上传下载功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。文件上传文件上传是项目开发中最常见的功能。为了能上传文件,必须将表单的method设置为POST,并将e
2023-05-31

Vue下如何用递归组件实现一个可折叠的树形菜单

这篇文章主要介绍“Vue下如何用递归组件实现一个可折叠的树形菜单”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue下如何用递归组件实现一个可折叠的树形菜单”文章能帮助大家解决问题。在Vue.js中
2023-07-04

如何使用MySQL和Java实现一个简单的文件下载功能

如何使用MySQL和Java实现一个简单的文件下载功能在现今的信息时代,文件下载已经成为了我们日常生活中不可或缺的一部分。无论是从互联网上下载文档、音乐、视频等媒体文件,还是从企业服务器上下载业务相关的文件,文件下载功能已经成为了许多应用程
2023-10-22

在Java项目中使用fileupload组件如何实现一个文件上传功能

本篇文章给大家分享的是有关在Java项目中使用fileupload组件如何实现一个文件上传功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。使用fileupload组件的原因:
2023-05-31

如何在Java项目中利用FasfDFS实现一个文件上传下载功能

本篇文章给大家分享的是有关如何在Java项目中利用FasfDFS实现一个文件上传下载功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一 : 添加配置文件当完成以上操作之后可以
2023-05-31

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录