全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

微信小程序 石头剪刀布实例代码

微信小程序 石头剪刀布

昨天看有个石头剪刀布的练习,就拿出来做了一下,布局的代码浪费了很多时间,果然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 


相关文章: 5种Android数据存储方式汇总  高性价比服务器租赁——企业级配置与24小时运维服务  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  焦点电影公司作品,电影焦点结局是什么?  网站制作价目表怎么做,珍爱网婚介费用多少?  简单实现Android文件上传  贸易公司网站制作流程,出口贸易网站设计怎么做?  如何快速生成可下载的建站源码工具?  太原网站制作公司有哪些,网约车营运证查询官网?  建站主机SSH密钥生成步骤及常见问题解答?  如何破解联通资金短缺导致的基站建设难题?  如何通过老薛主机一键快速建站?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  如何选择最佳自助建站系统?快速指南解析优劣  制作网站的基本流程,设计网站的软件是什么?  番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?  php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】  ,网页ppt怎么弄成自己的ppt?  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  如何在景安云服务器上绑定域名并配置虚拟主机?  建站之星如何保障用户数据免受黑客入侵?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  建站之星在线版空间:自助建站+智能模板一键生成方案  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  网站制作公司排行榜,抖音怎样做个人官方网站  如何选择高效响应式自助建站源码系统?  海南网站制作公司有哪些,海口网是哪家的?  武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?  建站上市公司网站建设方案与SEO优化服务定制指南  如何快速生成凡客建站的专业级图册?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  如何在阿里云服务器自主搭建网站?  如何用AWS免费套餐快速搭建高效网站?  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  建站之星导航如何优化提升用户体验?  教学论文网站制作软件有哪些,写论文用什么软件 ?  整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?  python的本地网站制作,如何创建本地站点?  网站好制作吗知乎,网站开发好学吗?有什么技巧?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  如何快速搭建自助建站会员专属系统?  c# 在ASP.NET Core中管理和取消后台任务  音乐网站服务器如何优化API响应速度?  道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?  企业网站制作公司网页,推荐几家专业的天津网站制作公司?  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  建站之星安装需要哪些步骤及注意事项? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。