uniApp自动摇筛子功能

<template>
	<view class="content">
		<view class="text-area">
			<rich-text class="title" :nodes="sum"></rich-text>
		</view>
		<view class="flex">
			<image class="logo" :src="arr[nums[0]]"></image>
			<image class="logo" :src="arr[nums[1]]"></image>
			<image class="logo" :src="arr[nums[2]]"></image>
		</view>
		<view class="btn"><button type="primary" @click="start">开始</button></view>
	</view>
</template>

<script>
export default {
	data() {
		return {
			timer: null,
			sum: "点击开始按钮摇骰子",
			nums: [0, 0, 0],
			arr: ['/static/1-.png', '/static/2-.png', '/static/3-.png', '/static/4-.png', '/static/5-.png', '/static/6-.png']
		};
	},
	onLoad() {
		this.picFn();
		let num = 0;
		this.nums.forEach(item => {num += item});
		// this.sum = `分数:${num+3}`;
	},
	methods: {
		start() {
			clearInterval(this.timer);
			this.sum = "等待计算中";
			this.timer = setInterval(this.picFn, 50);
			setTimeout(() => {
				clearInterval(this.timer);
				let num = 0;
				this.nums.forEach(item => {num += item});
				this.sum = `分数:${num+3}`;
			}, 3000);
		},
		randNum:() => Math.floor(Math.random() * 6),
		picFn(){ this.nums = this.nums.map(item => this.randNum())},
		
	}
};
</script>

<style>
.content {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.flex {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	flex-wrap: wrap;
}
.logo {
	height: 200rpx;
	width: 200rpx;
	margin-top: 50rpx;
	margin-left: 100rpx;
	margin-right: auto;
	margin-bottom: 50rpx;
}

.text-area {
	display: flex;
	justify-content: center;
}

.title {
	font-size: 36rpx;
	color: #8f8f94;
}
</style>

h5端:

 微信小程序端

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值