uniapp-vue3 实现, 一款带有丝滑动画效果的单选框组件,支持微信小程序、H5等多端

采用 uniapp-vue3 实现, 是一款带有丝滑动画效果的单选框组件,提供点状、条状的动画过渡效果,支持多项自定义配置,适配 web、H5、微信小程序(其他平台小程序未测试过,可自行尝试)

可到插件市场下载尝试: https://ext.dcloud.net.cn/plugin?id=21740

  • 使用示例




  • 示例代码
javascript 复制代码
<template>
	<view>
		<view class="light" style="background-color: white">
			<view>
				<view class="flex-center">默认样式</view>
				<wo-radio-hopping></wo-radio-hopping>
			</view>
		</view>
		<view class="light" style="background-color: white">
			<view class="flex-center">数据集、默认选中、选中事件</view>
			<wo-radio-hopping v-model:options="state.items" v-model:defaultValue="state.default" @on-change="changeEvent"></wo-radio-hopping>
		</view>
		<view class="light" style="background-color: white">
			<view>
				<view class="flex-center">条状动画</view>
				<wo-radio-hopping :lineAnimation="true"></wo-radio-hopping>
			</view>
		</view>
		<view class="light" style="background-color: white">
			<view>
				<view class="flex-center">主题色</view>
				<wo-radio-hopping :primary="'#55bc8a'"></wo-radio-hopping>
			</view>
		</view>
		<view class="light" style="background-color: white">
			<view>
				<view class="flex-center">方框</view>
				<wo-radio-hopping :circle="false"></wo-radio-hopping>
			</view>
		</view>
		<view class="light" style="background-color: white">
			<view>
				<view class="flex-center">选择框样式(通过css的box-shadow属性去设置)</view>
				<wo-radio-hopping :frameBoxShadow="''"></wo-radio-hopping>
				<wo-radio-hopping :frameBoxShadow="'0 1px 1px rgba(0, 0, 0, 0.2), 0 2px 1px rgba(0, 0, 0, 0.2) inset'"></wo-radio-hopping>
			</view>
		</view>
		<view class="light" style="background-color: white">
			<view style="padding: 0 20px;">
				<view class="flex-center">插槽自定义内容</view>
				<wo-radio-hopping v-model:options="state.items" v-slot="slotProps" @on-change="changeEvent">
					<view style="display: flex; justify-content: space-between;padding: 10px;">
						<view>{{ slotProps.data.label }}</view>
						<view class="tag">{{ slotProps.data.tag }}</view>
					</view>
				</wo-radio-hopping>
			</view>
		</view>
		<view class="dark">
			<view>
				<view class="flex-center">暗黑模式</view>
				<wo-radio-hopping v-model:options="state.items" v-slot="slotProps" @on-change="changeEvent">
					<view style="display: flex; justify-content: space-between;">
						<view>{{ slotProps.data.label }}</view>
						<view class="tag">{{ slotProps.data.tag }}</view>
					</view>
				</wo-radio-hopping>
			</view>
		</view>
	</view>
	
</template>

<script setup lang="ts">
	import { reactive } from 'vue';
	const state = reactive({
	  items: [{
				value: '1',
				label: '苹果味',
				tag: '饮料'
			},
			{
				value: '2',
				label: '香蕉味',
				tag: '酒水'
			},
			{
				value: '3',
				label: '火龙果味',
				tag: '饮料'
			},
			{
				value: '4',
				label: '西瓜味',
				tag: '饮料'
			},
			{
				value: '5',
				label: '哈密瓜味',
				tag: '酒水'
			},
			{
				value: '6',
				label: '榴莲味',
				tag: '酒水'
		}],
		default: '4',
	});
	const changeEvent = (el) => {
		console.log('点击:', el);
	}
</script>

<style lang="scss" scoped>
	.flex-center {
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.light {
		border-radius: 10px;
		padding: 20rpx;
		font-size: 24rpx;
		background-color: hsl(223,90%,90%);
		overflow: auto;
	}
	.dark {
		border-radius: 10px;
		padding: 20rpx;
		font-size: 24rpx;
		background-color: hsl(223,90%,10%);
		color: white;
		overflow: auto;
	}
	.tag {
		background-color: #1BA035;
		color: white;
		font-size: 10px;
		display: flex;
		align-items: center;
		justify-content: center;
		border-radius: 4px;
		padding: 0 4px;
	}
</style>
相关推荐
CHB3 小时前
HDC2026 演讲实录|AI 驱动的跨端进化:利用 uni-agent 快速构建高性能鸿蒙应用
uni-app·harmonyos
Haibakeji8 小时前
长沙餐饮门店点餐配送小程序定制开发
大数据·小程序
2501_915918419 小时前
iOS App性能测试工具的实现方法与优化循环指南
android·ios·小程序·https·uni-app·iphone·webview
玩烂小程序10 小时前
微信小程序手串DIY功能开发实录:飞入动画 + 环形排布 + 拖拽换序 + 旋转查看 + 保存设计
微信小程序
程序鉴定师10 小时前
2026济南十大App制作公司测评(精简版):覆盖小程序、定制开发与跨平台方案
大数据·小程序
斯内普吖11 小时前
(开源)高校素拓分管理系统小程序实战指南 基于 Java + SpringBoot + uni-app + Vue + MySQL
java·spring boot·mysql·小程序·uni-app·开源
何时梦醒11 小时前
HTML5 Canvas 从入门到实战:手把手教你打造一款"打飞机"小游戏
微信小程序
海阔天空668812 小时前
uniapp开启调试模式
uni-app·uniapp开启调试模式
master33612 小时前
SSL 证书链问题导致微信小程序无法正常工作
网络协议·微信小程序·ssl
anyup1 天前
分享 5 套 uni-app 实用主题,一键适配暗黑模式
前端·uni-app·视觉设计