vue列表自动滚动实例
更新时间:2023年10月09日 08:48:13 作者:学不会190
这篇文章主要介绍了vue列表自动滚动实例代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
vue列表自动滚动
想要实现vue列表数据自动滚动,鼠标划入列表滚动停止
就是这样的效果
下面上代码
首先安装 npm install vue-seamless-scroll --save
npm install vue-seamless-scroll --save
在需要的页面引入
import vueSeamlessScroll from "vue-seamless-scroll";
使用
<vueSeamlessScroll :data="vehicleRecordListData" class="seamless-warp" :class-option="defaultOption" > <ul class="item"> <li v-for="(item, index) in vehicleRecordListData" :key="index" > <span class="title" v-text="item.inAutoPlate"></span> <span class="date" v-text="item.vehicleCategory"></span> <span class="date" v-text="item.isInOrOut"></span> <span>{{ item.inOrOutTime | dateFormatValue }}</span> <span>{{ item.inOrOutType }}</span> <span>{{ item.inOrOutLaneName }}</span> </li> </ul> </vueSeamlessScroll>
配置项
key | description | default | val |
step | 数值越大速度滚动越快 | 1 | Number |
limitMoveNum | 开启无缝滚动的数据量 | 5 | Number |
hoverStop | 是否启用鼠标hover控制 | true | Boolean |
direction | 方向 0 往下 1 往上 2向左 3向右 | 1 | Number |
openTouch | 移动端开启touch滑动 | true | Boolean |
singleHeight | 单步运动停止的高度(默认值0是无缝不停止的滚动) direction => 0/1 | 0 | Number |
singleWidth | 单步运动停止的宽度(默认值0是无缝不停止的滚动) direction => 2/3 | 0 | Number |
waitTime | 单步停止等待时间(默认值1000ms) | 1000 | Number |
vue列表 自动滚动 加 鼠标滚轮
<template> <div class="scroll-container" id="scrollContainer"> <Scroll :id="'service'"> <template> <!-- <div v-for="(item,idx) in scrollListData" :key="idx + 'n'" class="service" @click="rowClick(item)"> {{item.name}} </div> --> <ul> <li v-for="(item,idx) in scrollListData" :key="idx + 'n'" class="service" @click="rowClick(item)"> <div class="service-chaild">{{ item.name }}</div> <div class="service-chaild">{{ item.value }}</div> </li> </ul> </template> </Scroll> </div> </template> <script> import Scroll from "@/components/HelloWorld"; export default { name: 'TestPage', components: { Scroll }, data() { return { scrollListData: [{ name: '嘉兴', value: '5555' }, { name: '上海', value: '5555' }, { name: '苏州', value: '5555' }, { name: '南京', value: '5555' }, { name: '嘉兴', value: '5555' }, { name: '上海', value: '5555' }, { name: '苏州', value: '5555' }, { name: '南京', value: '5555' }, { name: '嘉兴', value: '5555' }, { name: '上海', value: '5555' }, { name: '苏州', value: '5555' }, { name: '南京', value: '5555' } ] }; }, methods: { rowClick(row) { console.log(row, 'row ==================') } }, }; </script> <style> .scroll-container { height: 200px; width: 200px; margin-bottom: 20px; } .service { font-size: 12px; line-height: 18px; cursor: pointer; display: flex; } .service:nth-child(odd) { background: yellow; } .service:nth-child(even) { background: orange; } .service-chaild { height: 50px; } </style>
<template> <div class="scrollContainer" :id="id" @mouseenter="monseenter" @mouseleave="mouseleave"> <slot></slot> </div> </template> <script> export default { name: 'ScrollList', props: { id: String }, data() { return { timer: null }; }, methods: { init() { this.setTimer(); // this.$once代表只执行一次。如果组件是在keep-alive中包裹,则需要更换函数 // 被keep-alive包裹住的组件有两个生命周期函数:activated和deactivated this.$once('hook:beforeDestroy', () => { this.removeTimer(); }); }, removeTimer() { if (this.timer) { clearInterval(this.timer); this.timer = null; } }, setTimer() { this.removeTimer(); this.timer = setInterval(() => { // pixel height:include el and padding read only const scrollHeight = document.getElementById(this.id).scrollHeight; // visible area height:include el and padding read only const clientHeight = document.getElementById(this.id).clientHeight; const heightDifference = scrollHeight - clientHeight; // scroll height:readable and writable document.getElementById(this.id).scrollTop++; // when el scroll to top if (document.getElementById(this.id).scrollTop >= heightDifference - 1) { this.removeTimer(); // make it go back to original location after one second setTimeout(() => { document.getElementById(this.id).scrollTop = 0; this.setTimer(); }, 1000); } }, 44); }, monseenter() { this.removeTimer(); }, mouseleave() { this.setTimer(); } }, mounted() { this.init(); } }; </script> <style> .scrollContainer::-webkit-scrollbar { width: 4px; background: aliceblue; } .scrollContainer::-webkit-scrollbar-thumb { background: palevioletred; border-radius: 5px; } .scrollContainer { height: 100%; overflow: scroll; overflow-x: hidden; } /* // 兼容IE */ .scrollContainer { /*三角箭头的颜色*/ scrollbar-arrow-color: #fff; /*滚动条滑块按钮的颜色*/ scrollbar-face-color: #0099dd; /*滚动条整体颜色*/ scrollbar-highlight-color: #0099dd; /*滚动条阴影*/ scrollbar-shadow-color: #0099dd; /*滚动条轨道颜色*/ scrollbar-track-color: #0066ff; /*滚动条3d亮色阴影边框的外观颜色——左边和上边的阴影色*/ scrollbar-3dlight-color: #0099dd; /*滚动条3d暗色阴影边框的外观颜色——右边和下边的阴影色*/ scrollbar-darkshadow-color: #0099dd; /*滚动条基准颜色*/ scrollbar-base-color: #0099dd; } </style>
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
vue3使用vuedraggable和grid实现自定义拖拽布局方式
这篇文章主要介绍了vue3使用vuedraggable和grid实现自定义拖拽布局方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-06-06
最新评论