vue 列表无限无缝滚动

1.通过 transform中的translate 属性进行列表的不断位移。

2.由于列表一直滚动到最后,会出现短暂的区域空白,然后再从头开始滚动。解决这个问题,就是通过在列表后面复制一个相同的列表。

3.以下是通过VUE3实现的一个列表滚动的一个小demo(全部代码)

<template>
	<div class="content" @mouseenter="mouseenter" @mouseleave="mouseleave">
		<div class="scroll_list" :style="{ transform: `translate(0px,-${scrollTop}px)` }">
			<div ref="scrollItemBox">
				<div class="scroll_item" v-for="(item, index) in dataList" :key="index">
					{{item.name}}
				</div>
			</div>
			<div v-html="copyHtmlData"></div>
		</div>
	</div>
</template>

<script setup>
	import {
		ref,
		onMounted,
		nextTick
	} from 'vue';

	let timer = ref(null)
	// 滚动的项目对象
	const scrollItemBox = ref('')
	// 列表高度
	const scrollBoxHeight = ref(0)
	//列表滚动高度
	const scrollTop = ref(0)
	//滚动的速度
	const speed = ref(15)
	// 列表数据
	const dataList = ref([{
		'name': '测试数据第一行',
	}, {
		'name': '测试数据第二行',
	}, {
		'name': '测试数据第三行',
	}, {
		'name': '测试数据第四行',
	}, {
		'name': '测试数据第五行',
	}, {
		'name': '测试数据第六行',
	}, {
		'name': '测试数据第七行',
	}, {
		'name': '测试数据第八行',
	}, {
		'name': '测试数据第九行',
	}, {
		'name': '测试数据第十行',
	}, {
		'name': '测试数据第十一行',
	}])
	//复制多一份防止滚动到后面出现空白
	const copyHtmlData = ref('')

	// 初始化滚动
	function initScroll() {
		nextTick(() => {
			copyHtmlData.value = scrollItemBox.value.innerHTML
			// 获取需要滚动盒子的高度
			scrollBoxHeight.value = scrollItemBox.value.offsetHeight
			startScroll()
		})
	}

	// 鼠标移入停止滚动
	function mouseenter() {
		clearInterval(timer.value);
	}

	// 鼠标移出继续滚动
	function mouseleave() {
		startScroll()
	}

	// 开始滚动
	function startScroll() {
		timer.value = setInterval(scroll, speed.value);
	}

	// 滚动处理方法
	function scroll() {
		scrollTop.value++
		// 当判断滚动的高度大于等于盒子高度时,从头开始滚动
		if (scrollTop.value >= scrollBoxHeight.value) {
			scrollTop.value = 0
		}
	}

	onMounted(() => {
		initScroll()
	});
</script>

<style scoped lang="scss">
	.content {
		height: 400px;
		border: 1px solid red;
		overflow: hidden;

		.scroll_list {
			transition: all 0ms ease-in 0s
		}

		.scroll_item {
			height: 50px;
			margin-bottom: 10px;
			background: pink;
			line-height: 40px;
			text-align: center;
			font-size: 14px;
		}
	}
</style>
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js是一种流行的JavaScript框架,用于构建用户界面。要实现无缝滚动效果,可以使用Vue.js的transition组件和CSS动画来实现。 首先,你需要在Vue组件中定义一个包含滚动内容的容器,并设置其样式为`overflow: hidden`,以隐藏超出容器的内容。然后,在容器内部创建一个滚动元素,设置其样式为`white-space: nowrap`,以使内容水平排列。 接下来,你可以使用Vue的transition组件来添加过渡效果。在滚动元素上添加一个`v-if`指令,根据件来决定是否显示滚动元素。当需要滚动时,将滚动元素的内容复制一份,并将其追加到滚动元素的末尾,形成一个无限循环的效果。 然后,你可以使用CSS动画来实现滚动效果。通过给滚动元素添加一个`transform`属性,并使用`translateX`函数来实现水平位移。同时,使用`animation`属性来定义动画的持续时间、缓动函数等。 最后,在Vue组件中使用定时器或者其他方式来触发滚动效果。可以通过改滚动元素的`transform`属性的值来实现滚动效果。 下面是一个简单的示例代码: ```html <template> <div class="scroll-container"> <div class="scroll-content" v-if="isScrolling"> {{ content }} </div> </div> </template> <script> export default { data() { return { content: '这是滚动的内容', isScrolling: true }; }, mounted() { setInterval(() => { // 每隔一段时间改变滚动元素的transform属性值,实现滚动效果 }, 3000); } }; </script> <style> .scroll-container { width: 300px; height: 200px; overflow: hidden; } .scroll-content { white-space: nowrap; animation: scrollAnimation 10s linear infinite; } @keyframes scrollAnimation { 0% { transform: translateX(0); } 100% { transform: translateX(-100%); } } </style> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值