三种方法实现轮播图配置,史上最简方法~

在这里插入图片描述
源代码:

<div class="conscroll">
	<div class="caroubtn" @click="toleft">&lt;</div>
    <ul class="viewlist">
    	<li class="single" v-for="item in list" :key="item.id">
      		<h4 class="sub_title">
      			<i :class="item.iconName" style="margin-right:0.5rem"></i>
      			{{item.productName}}
        		<i class="el-icon-s-promotion" @click="handleCheck(item.id)"></i>
      		</h4>
      		<div class="cont">{{item.carouselContent}}</div>
		</li>
	</ul>
	<div class="caroubtn" @click="toright">&gt;</div>
</div>
.conscroll{
  	height:500px;
  	width: 100%;
  	margin: 20px;
  	display: flex;
  	.caroubtn{
   		width: 60px;
    	height: 60px;
    	line-height: 60px;
    	text-align: center;
    	border-radius: 50%;
    	background: #65C6D4;
    	margin: auto;
    	font-size: 2rem;
    	color: #fff;
    	cursor: pointer;
  	}
  	.viewlist{
    	display: flex;
    	margin: 0 auto;
    	overflow: hidden;
    	width: 1340px;	//260px * 5 + 10px * 4
    	.single{
      		width: 260px;
      		height: 100%;
      		margin-right: 10px;
      		box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.1);
      		border-radius: 5px;
      		color: #fff;
      		padding: 10px;
      		&:nth-child(5n+1) {
        		background: linear-gradient(360deg, #FF8C6F 0%, #FF6773 100%);
      		}	
      		&:nth-child(5n+2) {
        		background: linear-gradient(360deg, #6962D2 0%, #A366A7 100%);
      		}
      		&:nth-child(5n+3) {
        		background: linear-gradient(360deg, #65C6D4 0%, #037EB7 100%);
      		}
      		&:nth-child(5n+4) {
        		background: linear-gradient(360deg, #9793E8 0%, #5149F9 100%);
      		}
      		&:nth-child(5n+5) {
        		background: linear-gradient(360deg, #35ACEC 0%, #1F8AF0 100%);
      		}
      		.sub_title{
      			height: 10%;
     			font-size: 14px;
     			.el-icon-s-promotion{
     				font-size: 16px;
        			float: right;
        			margin-right: 10px;
      			}
     		}
      		.cont{
      			height: 90%;
      			font-size: 10px;
        		font-weight: 400;
        		color: #FFF;
        		line-height: 20px;
        		overflow-y: scroll;
      		}
    	}
  	}
}

vue-seamless-scroll

vue-seamless-scroll是一个基于Vue.js的简单无缝滚动组件,基于requestAnimationFrame实现,配置多满足多样需求。目前支持上下左右无缝滚动,单步滚动,以及支持水平方向的手动切换功能。

  • vue-seamless-scroll组件在线演示文档

  • 安装:

    • Npm:npm install vue-seamless-scroll --save
    • Yarn:yarn add vue-seamless-scroll
    • 浏览器CDN:https://cdn.jsdelivr.net/npm/vue-seamless-scroll@latest/dist/vue-seamless-scroll.min.js
  • 使用:

    • 引入:import vueSeamlessScroll from 'vue-seamless-scroll'
    • 配置:components: { vueSeamlessScroll },
    • 使用:<vue-seamless-scroll></vue-seamless-scroll>
  • 配置项:

属性描述默认值数据类型
step数值越大速度滚动越快1Number
limitMoveNum开启无缝滚动的数据量5Number
hoverStop是否启用鼠标hover控制trueBoolean
direction方向 0 往下 1 往上 2向左 3向右1Number
openTouch移动端开启touch滑动trueBoolean
singleHeight单步运动停止的高度(默认值0是无缝不停止的滚动) direction => 0/10Number
singleWidth单步运动停止的宽度(默认值0是无缝不停止的滚动) direction => 2/30Number
waitTime单步停止等待时间(默认值1000ms)1000Number
switchOffset左右切换按钮距离左右边界的边距(px)30Number
autoPlay1.1.17版本前手动切换时候需要置为falsetrueBoolean
switchSingleStep手动单步切换step值(px)134Number
switchDelay单步切换的动画时间(ms)400Number
switchDisabledClass不可以点击状态的switch按钮父元素的类名disabledString
isSingleRemUnitsingleHeight and singleWidth是否开启rem度量falseBoolean
navigation左右方向的滚动是否显示控制器按钮,true的时候autoPlay自动变为falsefalseBoolean

Carousel

Carousel 是Element.ui中的组件,可以在有限空间内,循环播放同一类型的图片、文字等内容。

推荐使用 npm 的方式安装,它能更好地和 webpack 打包工具配合使用:npm i element-ui -S

引入时只需要在项目的main.js文件中引入整个 Element即可(也可以按需引入,以减小项目体积)。

import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.use(ElementUI);

官网:Carousel组件详细介绍

数组的增添和删除

每次点击轮播按钮时,只需要将数组中的元素调换位置即可,向左轮播时,将数组的第一个元素移除并添加到数组末尾;向右轮播时,将数组的最后一个元素移除并添加到数组开头。

toleft(){
	let list = this.list
	this.list.push(list.shift())
},
toright(){
	let list = this.list
	this.list.unshift(list.pop())
}

这个方法纯属取巧,但使用特别简便,对数组api不熟悉的同学可以看我的JavaScript学习笔记(六)-- 数组,希望对你有所帮助~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTML实现手机端轮播图可以使用CSS3的动画特性来实现,也可以使用JavaScript库来实现。而在移动端,推荐使用Swiper来实现轮播图。下面分别介绍两种实现方式。 ## HTML实现手机端轮播图 ### 使用CSS3动画实现 HTML结构: ```html <div class="slider"> <img src="image1.jpg"> <img src="image2.jpg"> <img src="image3.jpg"> </div> ``` CSS样式: ```css .slider { width: 100%; height: 300px; overflow: hidden; position: relative; } .slider img { width: 100%; height: 100%; position: absolute; left: 0; top: 0; opacity: 0; animation: slide 5s infinite; } @keyframes slide { 0% { opacity: 0; } 20% { opacity: 1; } 80% { opacity: 1; } 100% { opacity: 0; } } .slider img:nth-child(2) { animation-delay: 1s; } .slider img:nth-child(3) { animation-delay: 3s; } ``` 上面的代码会让轮播图中的图片循环轮播,每张图片停留5秒钟,并且使用了CSS3的动画特性来实现。 ### 使用JavaScript实现 可以使用一些JavaScript库来实现手机端的轮播图,比如Swiper、Slick等。这里以Swiper为例进行介绍。 HTML结构: ```html <div class="swiper-container"> <div class="swiper-wrapper"> <div class="swiper-slide"><img src="image1.jpg"></div> <div class="swiper-slide"><img src="image2.jpg"></div> <div class="swiper-slide"><img src="image3.jpg"></div> </div> </div> ``` CSS样式: ```css .swiper-container { width: 100%; height: 300px; } .swiper-slide img { width: 100%; height: 100%; } ``` JavaScript代码: ```javascript var mySwiper = new Swiper('.swiper-container', { autoplay: { delay: 5000, }, loop: true, pagination: { el: '.swiper-pagination', }, }); ``` 上面的代码会让轮播图中的图片循环轮播,每张图片停留5秒钟,并且使用了Swiper库来实现。 ## Swiper移动端轮播图简单实现 Swiper是一款移动端的JavaScript库,可以很方便地实现轮播图。下面是一个简单的Swiper轮播图实现代码。 HTML结构: ```html <div class="swiper-container"> <div class="swiper-wrapper"> <div class="swiper-slide"><img src="image1.jpg"></div> <div class="swiper-slide"><img src="image2.jpg"></div> <div class="swiper-slide"><img src="image3.jpg"></div> </div> <div class="swiper-pagination"></div> </div> ``` CSS样式: ```css .swiper-container { width: 100%; height: 300px; } .swiper-slide img { width: 100%; height: 100%; } ``` JavaScript代码: ```javascript var mySwiper = new Swiper('.swiper-container', { autoplay: { delay: 5000, }, loop: true, pagination: { el: '.swiper-pagination', }, }); ``` 上面的代码会让轮播图中的图片循环轮播,每张图片停留5秒钟,并且使用了Swiper库来实现

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值