昨天看有個石頭剪刀布的練習,就拿出來作了一下,佈局的代碼浪費了不少時間,果真CSS這塊的還不是很熟練,下面直接上圖上代碼了。
JS:小程序
var numAi = 0數組
var timer緩存
Page({ide
data:{佈局
//控制按鈕是否可點擊flex
btnState:false,this
//記錄獲勝次數spa
winNum:0,orm
//中間的話「Ho~ You Win」blog
gameOfPlay:'',
//用戶選擇的圖片
p_w_picpathUserScr:'/pages/p_w_picpath/wenhao.png',
//電腦隨機的圖片
p_w_picpathAiScr:'',
//石頭剪刀布圖片數組
srcs:[
'/pages/p_w_picpath/shitou.png',
'/pages/p_w_picpath/jiandao.png',
'/pages/p_w_picpath/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({
p_w_picpathUserScr:this.data.srcs[e.currentTarget.id]
});
//清除計時器
clearInterval(timer);
//獲取數據源
var user = this.data.p_w_picpathUserScr;
var ai = this.data.p_w_picpathAiScr;
var num = this.data.winNum;
var str = '0.0~\nYou Lost!';
//判斷是否獲勝
if( user == "/pages/p_w_picpath/shitou.png" && ai == "/pages/p_w_picpath/jiandao.png"){
//獲勝後增長次數、改變文字內容、重新緩存獲勝次數
num++;
str = 'Ho~\nYou Win!';
wx.setStorageSync('winNum', num);
};
if(user == "/pages/p_w_picpath/jiandao.png" && ai == "/pages/p_w_picpath/bu.png"){
num++;
str = 'Ho~\nYou Win!';
wx.setStorageSync('winNum', num);
};
if(user== "/pages/p_w_picpath/bu.png" && ai == "/pages/p_w_picpath/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的,石頭剪刀布相應的圖片。
p_w_picpathAiScr: this.data.srcs[numAi],
})
numAi++;
},
again(){
//控制按鈕
if(this.data.btnState == false){
return;
}
//重新開始計時器
this.timerGo();
//刷新數據
this.setData({
btnState:false,
gameOfPlay:'',
p_w_picpathUserScr:'/pages/p_w_picpath/wenhao.png'
});
}
})
.WXML
<view class="downView" >
<text class="winNum">你已經獲勝了<text style="color:red">`winNum`</text>次</text>
<view class="showView">
<p_w_picpath src="`p_w_picpathAiScr`" class="gesturesImgL"></p_w_picpath>
<text class="winOrLost">`gameOfPlay`</text>
<p_w_picpath src="`p_w_picpathUserScr`" class="gesturesImgR"></p_w_picpath>
</view>
<view class="chooseForUserView">
<text class="winNum">出拳吧,少年~</text>
<view class="choose-V">
<block wx:for="`srcs`">
<view class="choose-view" bindtap="changeForChoose" id="`index`">
<p_w_picpath class="choose-p_w_picpath" src="`item`" ></p_w_picpath>
</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-p_w_picpath{
height: 160rpx;
width: 160rpx;
border-radius:80rpx;
}
/*再來*/
.againBtn{
margin:80rpx;
background: #FAE738;
}
demo資源下載:小程序-石頭剪刀布