vue實(shí)現(xiàn)井字棋游戲
本文實(shí)例為大家分享了vue實(shí)現(xiàn)井字棋游戲的具體代碼,供大家參考,具體內(nèi)容如下
之前看react的教程時(shí)看到的小游戲,試著用vue做一個(gè)。右邊的winner提示勝者,還沒(méi)有勝者時(shí)提示下一個(gè)棋子的種類(lèi)。restart按鈕點(diǎn)擊可重新開(kāi)始。go to step可跳轉(zhuǎn)到第n步。
html:
<div id="app"> <ul id="board" class="white normal"> <li class="square" v-for="i, idx in datas" @click=set(idx)>{{i}}</li> </ul> <div id="console"> <div id="hint" class="white">{{hint}}</div> <input type="button" class="white" id="restart" value="restart" @click="init()"/> <ul id="history" class="normal"> <li class="history" v-for="i, idx in history"> <input type="button" class="white" :value="'go to step' + (idx + 1)" @click=jump(idx) /> </li> </ul> </div> </div>
css:
<style type="text/css"> body { background: #5af; } .white { background: #fff; border-radius: 11px; outline: none; border: none; } .normal { list-style: none; padding: 0px; margin: 0px; } #app { display: flex; justify-content: space-between; width: 450px; height: 306px; position: absolute; top: 0; bottom: 0; left: 0; right: 0; margin: auto; } #board { display: flex; width: 306px; height: 306px; flex-wrap: wrap; overflow: hidden; } #hint { width: 100px; height: 22px; text-align: center; margin: 10px; } #restart { width: 70px; height: 22px; margin: 10px; } #history, .history { margin: 5px; } .square { height: 100px; width: 100px; border: #ebebeb solid 1px; flex: 0 0 auto; font-size: 50px; font-weight: 900; line-height: 100px; text-align: center; } </style>
js:
new Vue({ el: '#app', data: { datas: Array(9).fill(''), history: [], next: true, winner: '', cases: [ [0, 1, 2], [3, 4, 5], [6, 7, 8], [0, 3, 6], [1, 4, 7], [2, 5, 8], [0, 4, 8], [2, 4, 6], ] }, methods: { //放置棋子 set(idx) { if (!this.datas[idx] && !this.winner) { this.$set(this.datas, idx, this.next_player); this.history.push({ status: [...this.datas], player: this.next }); if (this.is_win(this.next_player)) { this.winner = this.next_player; } this.next = !this.next; } }, //跳轉(zhuǎn)到第n步 jump(idx) { this.datas = this.history[idx].status; this.history.splice(idx + 1, this.history.length - idx - 1); this.next = !this.history[idx].player; this.winner = this.is_win('O') ? 'O' : this.is_win('X') ? 'X' : ''; }, //判斷是否勝出 is_win(player) { return this.cases.some(arr => arr.every(el => this.datas[el] === player)); }, //初始化 init() { this.datas = Array(9).fill(''); this.history = []; this.next = true; this.winner = ''; } }, computed: { next_player() { return this.next ? 'O' : 'X'; }, hint() { return this.winner ? 'winner: ' + this.winner : 'next: ' + this.next_player; } } })
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue實(shí)現(xiàn)省市區(qū)級(jí)聯(lián)下拉選擇框
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)省市區(qū)級(jí)聯(lián)下拉選擇框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03element-ui 上傳圖片后清空?qǐng)D片顯示的實(shí)例
今天小編就為大家分享一篇element-ui 上傳圖片后清空?qǐng)D片顯示的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09table表格中使用el-popover 無(wú)效問(wèn)題解決方法
這篇文章主要介紹了table表格中使用el-popover 無(wú)效問(wèn)題解決方法,實(shí)例只針對(duì)單個(gè)的按鈕管用在表格里每一列都有el-popover相當(dāng)于是v-for遍歷了 所以我們?cè)谟|發(fā)按鈕的時(shí)候并不是單個(gè)的觸發(fā)某一個(gè),需要的朋友可以參考下2024-01-01vue 表單之通過(guò)v-model綁定單選按鈕radio
這篇文章主要介紹了vue 表單之v-model綁定單選按鈕radio的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05詳解VueJS應(yīng)用中管理用戶(hù)權(quán)限
本篇文章主要給大家講述了VueJS應(yīng)用中管理用戶(hù)權(quán)限的詳細(xì)過(guò)程和方法,以及相關(guān)的代碼展示,需要的朋友參考下吧。2018-02-02