---恢复内容开始---

  最近几天在学习小程序,看了网上的学习视频,于是自己捣鼓着做出了视频里面的小程序。

  这是实现的效果图

  一个小程序页面,一般有三个部分文件组成,index.js 这个文件里面放的是实现小程序的js代码;index.wxml文件里面放的是页面的结构层代码;相当于html,index.wxss放的是样式层代码,相当于css代码。

index.wxml运用的是小程序里面的组件,代码如下:

<!--index.wxml-->
<view class="container">
<text class="win-text">你已经获胜了</text>
<text class="win-num">{{winNum}}次</text>
<view class="result">
<image src="{{imgAi}}" class="imgAi"></image>
<text class="notice" >{{notice}}</text>
<image src="{{imgUser}}" class="imgUser"></image>
</view>
<view class="item">
<text class="notice-punches">出拳吧,少年~</text>
<block wx:for="{{srcs}}" wx:key="*this">
<view class="img-item" id="{{index}}" >
<image src="{{item}}" class="img-size" bindtap="userChooseImg"></image>
</view>
</block>
<button class="btn-again" bindtap="again">再来!</button>
</view>
</view>
 
 
index.js 的代码如下:
//index.js
//获取应用实例
var numAi = 0;
var timer;
Page({
data: {
srcs: [
'/pages/images/shiyou.jpg',
'/pages/images/jiandao.jpg',
'/pages/images/bu.jpg',
],
imgAi: '', // 电脑随机显示的图片
imgUser: '/pages/images/wenhao.jpg', // 用户选中的图片
notice: '', // 猜拳对比结果
winNum: wx.getStorageSync('winNum'), //用户猜拳赢的次数
btnpunches: false, // 是否点击出拳
},
onLoad: function () {
this.timerGo();
},
//设置电脑每间隔0.2s随机显示石头剪刀布
timerGo() {
timer = setInterval(this.change, 200);
},
//设置电脑随机显示石头剪刀布
change() {
if (numAi >= 3) {
numAi = 0;
}
this.setData({
imgAi: this.data.srcs[parseInt(Math.random() * 3)],
})
},
//当用户点击下面方框的石头剪刀布,将用户数据设置为对用的图片
userChooseImg(e) {
if (this.data.btnpunches == true) {
return;
}
var num = this.data.winNum;
this.setData({
notice: '你输了',
btnpunches: true,
})
if (e.currentTarget.offsetLeft == 155) {
this.setData({
imgUser: '/pages/images/shiyou.jpg',
})
//清除计时器
clearInterval(timer);
if (this.data.imgAi == '/pages/images/jiandao.jpg') {
num++;
wx.setStorageSync('winNum', num)
this.setData({
notice: '你赢了',
winNum: num,
})
}
} else if (e.currentTarget.offsetLeft == 280) {
this.setData({
imgUser: '/pages/images/jiandao.jpg',
})
//清除计时器
clearInterval(timer);
if (this.data.imgAi == '/pages/images/bu.jpg') {
num++;
wx.setStorageSync('winNum', num)
this.setData({
notice: '你赢了',
winNum: num,
})
}
} else {
this.setData({
imgUser: '/pages/images/bu.jpg',
})
//清除计时器
clearInterval(timer);
if (this.data.imgAi == '/pages/images/shitou.jpg') {
num++;
wx.setStorageSync('winNum', num)
this.setData({
notice: '你赢了',
winNum:num,
})
}
}
if (this.data.imgAi == this.data.imgUser) {
this.setData({
notice: '平局',
})
//清除计时器
clearInterval(timer);
}
},
//点击再来,电脑重新启动猜拳
again() {
//控制按钮
if (this.data.btnpunches == false) {
return;
}
this.timerGo();
this.setData({
btnpunches: false,
imgUser: '/pages/images/wenhao.jpg',
})
},
})
 
 
index.wxss文件的代码如下:
/**index.wxss**/
.container {
">yellow;
}
.win-text {
text-align: center;
}
.win-num {
color: red;
text-align: center;
}
.result {
height: 160px;
display: inline-block;
}
.notice {
width: 100px;
color: red;
/*height:140px;*//*line-height:140px;*/
text-align: center;
display: inline-block;
padding-top: 0px;
}
.imgAi {
width: 140px;
height: 140px;
padding: 10px 0 10px 10px;
}
.imgUser {
width: 140px;
height: 140px;
padding: 10px 0 10px 10px;
}
.item {
width: 92%;
height: 300px;
">#fff;
margin: 15px;
}
.notice-punches{
text-align:center;
display: block;
padding-top:20px;
}
.img-item {
display: inline-block;
padding: 25px 0 30px 15px;
}
.img-size {
width: 110px;
height: 110px;
border-radius: 50%;
}
.btn-again{
width:80%;
">yellow;
}
 
  该页面的实现到这里就结束了,谨以文来纪念我的第一个小程序的诞生。

---恢复内容结束---

最新文章

  1. HTML CSS 特殊字符表(转载)
  2. A Silverlight Bug ?
  3. SQL Server 2008中查看锁信息
  4. coocs2d-x资源压缩笔记
  5. Quartz定时任务学习(一)简单任务
  6. java 复习001
  7. PHP、Java、C#实现URI参数签名算法,确保应用与REST服务器之间的安全通信,防止Secret Key盗用、数据篡改等恶意攻击行为
  8. Linux网络管理——子网掩码
  9. 聊聊 Material Design 里,阴影的那些事儿!
  10. Intellij idea破解办法
  11. 安卓java.lang.IllegalArgumentException: The observer is null.解决方案
  12. Coursera-AndrewNg(吴恩达)机器学习笔记——第二周编程作业
  13. python的requests模块参数详解
  14. python学习笔记七——字典
  15. 移动端自动化测试-Mac-IOS-Appium环境搭建
  16. 每日英语:A Chinese Soccer Club Has Won Something!
  17. python导入模块总结与分析
  18. [BZOJ3203][SDOI2013]保护出题人(凸包+三分)
  19. python二维码操作:QRCode和MyQR入门
  20. hadoop job -kill 和 yarn application -kill 区别

热门文章

  1. scala资料总结,一些小技巧
  2. UA判断打开页面的环境,然后在callBack写相应环境下的回调函数
  3. python的for循环、下标和切片
  4. 2019-10-24-dotnet-列表-Linq-的-Take-用法
  5. 【codeforces 761A】Dasha and Stairs
  6. P1065 汪老师的烟
  7. P1061 最长连号
  8. 2019-9-2-C#命令行解析工具
  9. H3C MSTP
  10. Vue中qs插件的使用