美文网首页
井字过三关

井字过三关

作者: 南昌大魔王 | 来源:发表于2019-05-14 15:34 被阅读0次

说明

井字过三关,js实现代码。

截图

image.png

demo地址

https://codepen.io/ncbigdevil/full/OYROOW

具体代码

<!DOCTYPE html>
<html>
<head>
    <title>井字过三关</title>
    <!-- 最新版本的 Bootstrap 核心 CSS 文件 -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
    <style type="text/css">

    .main table{
        margin: 50px auto;

    }
    #game tr td {
        border: 1px solid #CCC;
        width: 100px;
        height: 100px;
        font-size: 65px;
        text-align: center;
        vertical-align: middle;
    }
    #game tr th {
        text-align: center;
    }
    .btn-group {
        margin: 10px;
    }
    #tips {
        font-size: 20px;
        color: orange;
        height: 40px;
        line-height: 30px;
    }

    </style>
</head>
<body>
    <div class="main">
        

        <table id="game">
            <tr>
                <th colspan="3">
                    <div class="btn-group config1" role="group" >
                      <button type="button" class="btn btn-primary" id="first">先手</button>
                      <button type="button" class="btn btn-default" id="last">后手</button>
                    </div>
                    <div class="btn-group config2" role="group" >
                      <button type="button" class="btn btn-primary" id="circle">使用〇</button>
                      <button type="button" class="btn btn-default" id="cross">使用X</button>
                    </div>
                </th>
            </tr>
            <tr>
                <th colspan="3">
                    <div id="tips">请点击开始按钮,开始游戏</div>
                </th>
            </tr>
            <tr>
                <td id='c1'></td>
                <td id='c2'>〇</td>
                <td id='c3'></td>
            </tr>
            <tr>
                <td id='c4'>〇</td>
                <td id='c5'>〇</td>
                <td id='c6'>〇</td>
            </tr>
            <tr>
                <td id='c7'></td>
                <td id='c8'>〇</td>
                <td id='c9'></td>
            </tr>
            <tr>
                <th colspan="3">
                    <div class="btn-group game-operation" role="group" >
                      <button type="button" class="btn btn-default" id="start">开始</button>
                      <button type="button" class="btn btn-primary" id="end">结束</button>
                    </div>
                </th>
            </tr>
        </table>
    </div>


    <script src="https://cdn.bootcss.com/jquery/3.4.0/jquery.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>

    <script type="text/javascript">
        var first = true;
        var myChoice = '〇';
        var computerChioce = 'X';
        var random = 0;
        var arrRecord = [];
        var flag = false;   //判断游戏是否结束,true是结束。
        const winCondition = [
            'c1c2c3',
            'c4c5c6',
            'c7c8c9',
            'c1c4c7',
            'c2c5c8',
            'c3c6c9',
            'c1c5c9',
            'c3c5c7'
        ];

        $(document).ready(function() {

            //开始函数
            $('.game-operation button').click(function() {
                if($(this).hasClass('btn-primary')) {
                    return;
                }

                finishGame ();
                if ($(this).attr('id') === 'start') {   
                    showTips('游戏中');
                    flag = false;
                    if (!first) {
                        computerPlay();
                    } 
                    $('#start').addClass('btn-primary').removeClass('btn-default');
                    $('#end').addClass('btn-default').removeClass('btn-primary');
                } else {
                    showTips('请点击开始按钮,开始游戏');
                    flag = true;
                    $('#start').addClass('btn-default').removeClass('btn-primary');
                    $('#end').addClass('btn-primary').removeClass('btn-default');
                }
            });

            //点击单元格触发的函数
            $('#game td').click(function() {

                if (flag) {
                    return;
                }

                if ($(this).hasClass('unselected')) {
                    $(this).text(myChoice).addClass('selected').removeClass('unselected').addClass('myChoice');
                    if (isWin()) {
                        return;
                    }
                    computerPlay();
                }
            });

            $('.config1 button').click(function() {
                if($(this).hasClass('btn-primary')) {
                    return;
                }
                if ($(this).attr('id') === 'first') {
                    first = true;
                    $('#first').addClass('btn-primary').removeClass('btn-default');
                    $('#last').addClass('btn-default').removeClass('btn-primary');
                } else {
                    first = false;
                    $('#first').addClass('btn-default').removeClass('btn-primary');
                    $('#last').addClass('btn-primary').removeClass('btn-default');
                }
            });
            
            $('.config2 button').click(function() {
                if($(this).hasClass('btn-primary')) {
                    return;
                }
                if ($(this).attr('id') === 'circle') {
                    myChoice = '〇';
                    computerChioce = 'X';
                    $('#circle').addClass('btn-primary').removeClass('btn-default');
                    $('#cross').addClass('btn-default').removeClass('btn-primary');
                } else {
                    myChoice = 'X';
                    computerChioce = '〇';
                    $('#circle').addClass('btn-default').removeClass('btn-primary');
                    $('#cross').addClass('btn-primary').removeClass('btn-default');
                }
            });


            function computerPlay () {
                let len = $('.unselected').length;
                if (len === 0 ) {
                    showTips('游戏完结');
                    return;
                }
                random = Math.floor(Math.random() * len);
                $($('.unselected')[random]).text(computerChioce).addClass('selected').removeClass('unselected').addClass('computerChioce');
                isWin();
            }

            function isWin() {
                let selectedCells = '';
                flag = false;
                $('.myChoice').each(function(index, item) {
                    selectedCells += $(item).attr('id');
                })

                winCondition.forEach(function(item) {
                    if (selectedCells.indexOf(item) > -1) {
                        flag = true;
                        showTips('你赢了');
                    }
                });

                if (!flag) {
                    $('.computerChioce').each(function(index, item) {
                        selectedCells += $(item).attr('id');
                    })

                    winCondition.forEach(function(item) {
                        if (selectedCells.indexOf(item) > -1) {
                            flag = true;
                            showTips('电脑赢了');
                        }
                    });
                }
                
                return flag;
            }

            function showTips (msg) {
                $('#tips').text(msg);
            }

            function finishGame () {
                
                

                $('#game td').text('').addClass('unselected').removeClass('selected').removeClass('myChoice').removeClass('computerChioce');
            }


        })

    </script>
</body>
</html>

相关文章

  • 井字过三关

    说明 井字过三关,js实现代码。 截图 demo地址 https://codepen.io/ncbigdevil/...

  • 【JQuery】“井字过三关”游戏

    虽然我是一名实打实的产品喵,但是为了能够和程序猿们愉快地沟通(让撕逼再和谐一点),我自学了一些代码知识,写了一些不...

  • 井字过三关的“倔强”

    初中时有一度很流行“井字过三关”。有一天我一连输了10多局给我同桌平平 ,一开始她拉我我玩我想说这有啥难的,输几局...

  • USMLE-会玩井字过三关就会血气分析

    前言: USMLE从菜鸟到食物链底层系列~ 和大家聊聊天而已~ 记得点赞哦~ 视频: 西瓜视频:https://b...

  • 我们常用的命理过三关

    过三关是俺们这行的核心技术,但是随着时代的变迁,很多规则已经慢慢改变了。 07年执业,11年才学会八字掌握过三关。...

  • 掌纹密码之井字纹

    手掌上出现井字形的纹路,称为「井字纹」,井字纹是属于吉祥的纹路。倘若有二个井字纹连在一起,称为「双井纹」,倘若有三...

  • 面相过三关

    没有直播 没有录音 本次讲座只能参加天津现场面授 江湖传说中的面相过三关 绝对失传已久秘技! 自古:传男不传女,传...

  • 井字棋

    package newPaca; import java.util.Scanner; public class j...

  • 井字决

    纵横交错星云路, 地脉穿行罗网中。 引殇流水落黄泉, 如封似闭难通天。

  • 井字游戏

    设计一个算法,判断玩家是否赢了井字游戏。输入是一个 N x N 的数组棋盘,由字符" ",“X"和"O"组成,其中...

网友评论

      本文标题:井字过三关

      本文链接:https://www.haomeiwen.com/subject/ecosaqtx.html