微信小程序 石头剪刀布实例代码
发布时间 - 2026-01-10 22:17:20 点击率:次微信小程序 石头剪刀布

昨天看有个石头剪刀布的练习,就拿出来做了一下,布局的代码浪费了很多时间,果然CSS这块的还不是很熟练,下面直接上图上代码了。
.js:
var numAi = 0
var timer
Page({
data:{
//控制按钮是否可点击
btnState:false,
//记录获胜次数
winNum:0,
//中间的话“Ho~ You Win”
gameOfPlay:'',
//用户选择的图片
imageUserScr:'/pages/image/wenhao.png',
//电脑随机的图片
imageAiScr:'',
//石头剪刀布图片数组
srcs:[
'/pages/image/shitou.png',
'/pages/image/jiandao.png',
'/pages/image/bu.png'
]
},
//生命周期,刚进来
onLoad: function () {
//获取本地缓存“已经获胜的次数”
var oldWinNum = wx.getStorageSync('winNum');
//如果有缓存,那么赋值,否则为0
if(oldWinNum != null && oldWinNum !=''){
this.data.winNum = oldWinNum;
}
this.timerGo();
},
//点击按钮
changeForChoose(e){
console.log();
if(this.data.btnState == true){
return;
}
//获取数组中用户的,石头剪刀布相应的图片。
this.setData({
imageUserScr:this.data.srcs[e.currentTarget.id]
});
//清除计时器
clearInterval(timer);
//获取数据源
var user = this.data.imageUserScr;
var ai = this.data.imageAiScr;
var num = this.data.winNum;
var str = '0.0~\nYou Lost!';
//判断是否获胜
if( user == "/pages/image/shitou.png" && ai == "/pages/image/jiandao.png"){
//获胜后增加次数、改变文字内容、从新缓存获胜次数
num++;
str = 'Ho~\nYou Win!';
wx.setStorageSync('winNum', num);
};
if(user == "/pages/image/jiandao.png" && ai == "/pages/image/bu.png"){
num++;
str = 'Ho~\nYou Win!';
wx.setStorageSync('winNum', num);
};
if(user== "/pages/image/bu.png" && ai == "/pages/image/shitou.png"){
num++;
str = 'Ho~\nYou Win!';
wx.setStorageSync('winNum', num);
};
//如果平局
if(user == ai){
str = 'Game Draw!';
}
//刷新数据
this.setData({
winNum:num,
gameOfPlay:str,
btnState:true
});
},
//开启计时器
timerGo(){
timer = setInterval(this.move,100);
},
//ai滚动方法
move(){
//如果大于等于3,重置
if(numAi>=3){
numAi=0;
}
this.setData({
//获取数组中Ai的,石头剪刀布相应的图片。
imageAiScr: this.data.srcs[numAi],
})
numAi++;
},
again(){
//控制按钮
if(this.data.btnState == false){
return;
}
//从新开始计时器
this.timerGo();
//刷新数据
this.setData({
btnState:false,
gameOfPlay:'',
imageUserScr:'/pages/image/wenhao.png'
});
}
})
.wxml:
<view class="downView" >
<text class="winNum">你已经获胜了<text style="color:red">{{winNum}}text>次text>
<view class="showView">
<image src="{{imageAiScr}}" class="gesturesImgL">image>
<text class="winOrLost">{{gameOfPlay}}text>
<image src="{{imageUserScr}}" class="gesturesImgR">image>
view>
<view class="chooseForUserView">
<text class="winNum">出拳吧,少年~text>
<view class="choose-V">
<block wx:for="{{srcs}}">
<view class="choose-view" bindtap="changeForChoose" id="{{index}}">
<image class="choose-image" src="{{item}}" >image>
view>
block>
view>
<button class="againBtn" bindtap="again">再来!button>
view>
view>
.wxss:
/*底*/
.downView{
width: 100%;
height: 1250rpx;
background: #FAE738;
margin: 0rpx;
text-align: center;
}
/*获胜次数*/
.winNum{
padding-top: 40rpx;
display: block;
font-size: 30rpx;
color: #363527;
font-weight:500;
}
/*展示出拳结果*/
.showView{
display: flex;
width: 100%;
margin-top:30rpx;
height: 200rpx;
}
.gesturesImgL{
height: 180rpx;
width: 180rpx;
margin-left:80rpx;
}
.gesturesImgR{
height: 180rpx;
width: 180rpx;
margin-right:80rpx;
}
.winOrLost{
color: orangered;
flex:1;
font-size: 30rpx;
margin-top:75rpx;
}
/*用户出拳*/
.chooseForUserView{
margin:40rpx;
height: 800rpx;
background: white;
text-align: center;
}
.choose-V{
display: flex;
margin-top: 40rpx;
}
.choose-view{
flex: 1;
content:none !important;
height: 140rpx;
width: 140rpx;
border:1px solid white;
}
.choose-image{
height: 160rpx;
width: 160rpx;
border-radius:80rpx;
}
/*再来*/
.againBtn{
margin:80rpx;
background: #FAE738;
}
demo资源下载 小程序-石头剪刀布
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# 微信小程序
# 石头剪刀布
# 石头剪刀布简单实例
# 石头剪刀布实例下载
# 微信小程序进行微信支付的步骤昂述
# 微信小程序-详解微信登陆、微信支付、模板消息
# 微信小程序 实战实例开发流程详细介绍
# 微信小程序 解决swiper不显示图片的方法
# 微信小程序 解决请求服务器手机预览请求不到数据的方法
# 使用DeviceOne实现微信小程序功能
# 详解微信小程序——自定义圆形进度条
# 微信小程序开发探究
# Android中微信小程序支付倒计时功能
# JS绘制微信小程序画布时钟
# JS中微信小程序自定义底部弹出框
# PHP:微信小程序 微信支付服务端集成实例详解及源码下载
# 计时器
# 出拳
# 再来
# 组中
# 有个
# 不是很
# 希望能
# 你已经
# 这块
# 来做
# 谢谢大家
# 则为
# 图上
# 判断是否
# 昨天
# 浪费了
# timerGo
# log
# console
# changeForChoose
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】
香港服务器部署网站为何提示未备案?
Laravel如何使用Gate和Policy进行授权?(权限控制)
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
深入理解Android中的xmlns:tools属性
Laravel怎么发送邮件_Laravel Mail类SMTP配置教程
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
Android okhttputils现在进度显示实例代码
Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧
Laravel如何配置Horizon来管理队列?(安装和使用)
网站制作免费,什么网站能看正片电影?
北京网站制作的公司有哪些,北京白云观官方网站?
VIVO手机上del键无效OnKeyListener不响应的原因及解决方法
Laravel怎么在Blade中安全地输出原始HTML内容
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
WEB开发之注册页面验证码倒计时代码的实现
Laravel如何使用.env文件管理环境变量?(最佳实践)
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法
油猴 教程,油猴搜脚本为什么会网页无法显示?
如何获取免费开源的自助建站系统源码?
网站建设要注意的标准 促进网站用户好感度!
Laravel如何优化应用性能?(缓存和优化命令)
魔方云NAT建站如何实现端口转发?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
如何在宝塔面板中修改默认建站目录?
Laravel怎么在Controller之外的地方验证数据
Laravel的路由模型绑定怎么用_Laravel Route Model Binding简化控制器逻辑
济南网站建设制作公司,室内设计网站一般都有哪些功能?
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
网易LOFTER官网链接 老福特网页版登录地址
如何用狗爹虚拟主机快速搭建网站?
Laravel如何使用查询构建器?(Query Builder高级用法)
Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】
浅析上传头像示例及其注意事项
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
如何在万网自助建站平台快速创建网站?
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
如何快速生成橙子建站落地页链接?
如何在搬瓦工VPS快速搭建网站?
nodejs redis 发布订阅机制封装实现方法及实例代码
移动端脚本框架Hammer.js
Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】
Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】
Laravel如何升级到最新版本?(升级指南和步骤)
php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)

