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>
相关推荐
江城开朗的豌豆1 分钟前
Vue-router方法大全:让页面跳转随心所欲!
前端·javascript·vue.js
程序员爱钓鱼11 分钟前
Go语言泛型-泛型约束与实践
前端·后端·go
前端小巷子13 分钟前
web从输入网址到页面加载完成
前端·面试·浏览器
江城开朗的豌豆14 分钟前
Vue路由动态生成秘籍:让你的链接'活'起来!
前端·javascript·vue.js
晓得迷路了14 分钟前
栗子前端技术周刊第 88 期 - Apache ECharts 6.0 beta、Deno 2.4、Astro 5.11...
前端·javascript·echarts
江城开朗的豌豆19 分钟前
在写vue公用组件的时候,怎么提高可配置性
前端·javascript·vue.js
江城开朗的豌豆20 分钟前
Vue路由跳转的N种姿势,总有一种适合你!
前端·javascript·vue.js
江城开朗的豌豆21 分钟前
Vue路由玩法大揭秘:三种路由模式你Pick谁?
前端·javascript·vue.js
江城开朗的豌豆21 分钟前
Vue路由守卫全攻略:给页面访问装上'安检门'
前端·javascript·vue.js
小磊哥er28 分钟前
【前端工程化】前端组件模版构建那些事
前端