uniapp自定义卡片轮播图

效果图

1、封装组件

<template>
	<view>

		<!-- 自定义卡片轮播 -->
		<swiper class="swiperBox" :previous-margin="swiper.margin" :next-margin='swiper.margin' :circular="true"
			@change="swiperChange">
			<swiper-item class="swiperItem" v-for="(item,index) in swiper.list" :key="index">
				<view class="swiperWrap" :class="{'active':swiper.index == index}">
					<view class="swiperPic">
						<image :src="item.url"></image>
					</view>
					<view class="swiperCon">
						<view class="swiperName">{{item.title}}</view>
						<view class="swiperPrice">
							<view class="group">
								<image src="/static/index/swiperGroup.png" mode="aspectFill"></image>
							</view>
							<view class="price">
								¥<text>{{item.price}}</text>
							</view>
						</view>
					</view>
				</view>
			</swiper-item>
		</swiper>

	</view>
</template>

<script>
	export default {
		data() {
			return {
				swiper: {
					margin: "150rpx",
					index: 0,
					list: [{
						url: 'https://cdn.uviewui.com/uview/swiper/swiper1.png',
						title: '谁念西风独自凉',
						price: '0.01',
					}, {
						url: 'https://cdn.uviewui.com/uview/swiper/swiper2.png',
						title: '沉思往事立残阳',
						price: '0.02',
					}, {
						url: 'https://cdn.uviewui.com/uview/swiper/swiper3.png',
						title: '沉思往事立残阳',
						price: '0.03',
					}]
				},
			}
		},
		components: {

		},
		mounted() {

		},
		methods: {
			//swiper滑动事件
			swiperChange(e) {
				this.swiper.index = e.detail.current;
			},
		}
	}
</script>

<style scoped lang="scss">
	.swiperBox {
		height: 500rpx;
		overflow: hidden;
	}

	.swiperItem {
		border-radius: 20rpx;
		overflow: hidden;
	}

	.swiperWrap {
		transform: scale(0.9);
		transition: transform 0.3s ease-in-out 0s;
	}

	.swiperWrap.active {
		transform: scale(1);
	}

	.swiperPic {
		width: 100%;
		height: 325rpx;
	}

	.swiperPic image {
		width: 100%;
		height: 100%;
	}

	.swiperCon {
		padding: 20rpx;
		background-color: #fff;
	}

	.swiperName {
		font-size: 32rpx;
		font-weight: bold;
		text-align: center;
	}

	.swiperPrice {
		width: 160rpx;
		height: 54rpx;
		border-radius: 28rpx;
		border: 2rpx solid $uni-theme;
		overflow: hidden;
		margin: 20rpx auto 0;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.group {
		width: 60rpx;
		height: 54rpx;
		background: $uni-theme;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.group image {
		width: 28rpx;
		height: 28rpx;
	}

	.price {
		width: 100rpx;
		height: 54rpx;
		font-size: 24rpx;
		color: $uni-theme;
		background-color: #fff;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.price text {
		font-size: 32rpx;
	}
</style>

2、组件引用

<template>
	<view>

        <swiperCard></swiperCard>

	</view>
</template>

<script>
	import swiperCard from "@/components/swiperCard/swiperCard"

	export default {
		components: {
			swiperCard
		},
		data() {
			return {
				
			}
		},

	}
</script>
相关推荐
Манго нектар24 分钟前
JavaScript for循环语句
开发语言·前端·javascript
蒲公英100131 分钟前
vue3学习:axios输入城市名称查询该城市天气
前端·vue.js·学习
天涯学馆1 小时前
Deno与Secure TypeScript:安全的后端开发
前端·typescript·deno
以对_1 小时前
uview表单校验不生效问题
前端·uni-app
程序猿小D2 小时前
第二百六十七节 JPA教程 - JPA查询AND条件示例
java·开发语言·前端·数据库·windows·python·jpa
奔跑吧邓邓子2 小时前
npm包管理深度探索:从基础到进阶全面教程!
前端·npm·node.js
软件开发技术深度爱好者2 小时前
用HTML5+CSS+JavaScript庆祝国庆
javascript·css·html5
前端李易安3 小时前
ajax的原理,使用场景以及如何实现
前端·ajax·okhttp
汪子熙3 小时前
Angular 服务器端应用 ng-state tag 的作用介绍
前端·javascript·angular.js
Envyᥫᩣ3 小时前
《ASP.NET Web Forms 实现视频点赞功能的完整示例》
前端·asp.net·音视频·视频点赞