vue 挑战最强大脑 记忆力5分 观察力5分 推理力4分

时间:2025-03-28 08:12:39

 

 首先在90s时间内记忆相同的图片位置

90s后覆盖所有图片,选手通过记忆观察所有相同照片的位置进行两两抵消(类似消消乐)

每消错一次,整个图片按照顺时针旋转90°,这里考验选手的记忆力和推理力

 有兴趣的小伙伴可以挑战一波了,看看你是不是最强大脑呢~

源代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="../../">
    <style>
        body,html{
            height: 100%;
            width: 100%;
        }
        #app{
            background: #333;
            height: 100%;
            width: 100%;
        }
        .puke-tips {
            text-align: center;
            font-size: 18px;
            color: #fff;
            padding-top: 30px;
        }

        .puke {
            width: 400px;
            margin: 20px auto;
            transition: transform 1s;
            transform-origin: center center 0;
        }

        .puke li {
            float: left;
            width: 100px;
            box-sizing: border-box;
            height: 100px;
            line-height: 100px;
            position: relative;
        }

        .puke li div {
            transition: transform 0.4s;
            position: absolute;
            top: 0;
            left: 0;
            height: 100%;
            width: 100%;
            background: url("") no-repeat;
            color: #58B7FF;
            border: 1px solid #ccc;
            font-size: 40px;
            text-align: center;
        }

        .puke {
            cursor: pointer;
        }
        .puke li .po1{
            background-position: 0 0;
        }
        .puke li .po2{
            background-position: -100px 0;
        }
        .puke li .po3{
            background-position: -200px 0;
        }
        .puke li .po4{
            background-position: -300px 0;
        }
        .puke li .po5{
            background-position: 0 -100px;
        }
        .puke li .po6{
            background-position: -100px -100px;
        }
        .puke li .po7{
            background-position: -200px -100px;
        }
        .puke li .po8{
            background-position: -300px -100px;
        }

        .puke div {
            background: url("") no-repeat center, #fff;
        }

        .puke div:first-child {
            z-index: 1;
            transform: rotateY(0deg);
        }

        .puke div:last-child {
            transform: rotateY(180deg);
        }

        .puke div:first-child {
            transform: rotateY(180deg);
        }

        .puke div:last-child {
            z-index: 1;
            transform: rotateY(0deg);
        }

        /*# sourceMappingURL=../../maps/vue-demos/poker/ */

    </style>
</head>
<body>
<div >
    <p class="puke-tips">记住牌子,在90秒时间内找出相同的牌子<span v-show="nowTime>0" class="ml30">记忆倒计时:{{nowTime}}</span><span v-show="endTime>0&&nowTime<=0" class="ml30">倒计时:{{endTime}}</span><span v-show="endTime<=0" class="ml30">游戏失败</span></p>
    <div class="puke clearfix" :style="{'transform':'rotate( '+pukeRotate+'deg)'}">
        <ul>
            <li v-for="item,index in puke" @click="pukeDo(item,index)" :class="[isStart||pukeNowIndex===index||pukeErrorIndex===index||()!==-1?'pukeNum':'pukeBg']"  :style="{'transform':'rotate( -'+pukeRotate+'deg)'}">
                <div class="zero"></div>
                <!--<div class="num" :class="{'po'+}"></div>-->
                <div class="num" :class="'po'+"></div>
            </li>
        </ul>

    </div>
</div>
</body>
<script src="../"></script>
<script type="text/javascript">
    new Vue({
        el:'#app',
        data:{
            //翻牌数组
            puke:[],
            //第一次翻牌的号码
            firstNumber:0,
            pukeNowIndex:-1,
            pukeErrorIndex:-1,
            //已经翻牌的号码
            checkEnd:[],
            //旋转角度
            pukeRotate:0,
            isStart:true,
            nowTime:15,
            endTime:90,
            pukeTimer:null,
            endTimer:null
        },
        methods:{
            /**
             * @description 初始化翻牌
             */
            initPuke(){
                =!;
                if(){
                    =true;
                    =15;
                    =90;
                    =[];
                    =[];
                    =0;
                    =-1;
                    =-1;
                    //准备翻牌数组
                    let pukeList=[1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8],pukeText='';
                    for(let i=0;i<16;i++){
                        pukeText=((() * ),1)[0];
                        ({
                            number:pukeText
                        })
                    }
                    //开始数据
                    =setInterval(()=>{
                            --;
                    if(<0){
                        clearInterval();
                        =false;
                        ();
                    }
                },1000)
                }
                else{
                    clearInterval();
                    clearInterval();
                }
            },
            /**
             * @description 翻牌倒计时
             */
            pukeIng(){
                =setInterval(()=>{
                    --;
                    if(<0){
                        clearInterval();
                        clearInterval();
                    }
                },1000);
            },
            /**
             * @description 翻牌操作
             * @param val 当前记录
             * @param i 当前记录索引
             */
            pukeDo(val,i){
                //号码是否已经有翻过的记录或者不在有效时间内翻牌
                if(||<0||===i||()!==-1){
                    return;
                }
                //是否是第一次翻牌
                if(===0){
                    //记录第一次的翻牌信息
                    =;
                    =i;
                }
                else{
                    //与第一次是否一致
                    if(===){
                        ()
                        =-1;
                        =-1;
                        //如果长度等于8就是全部已经翻完,游戏成功
                        if(===8){
                            alert('游戏成功!');
                            clearInterval();
                            clearInterval();
                        }
                    }
                    else{
                        //翻牌错误,重置
                        =i;
                        setTimeout(()=>{
                            =-1;
                        =-1;
                        //进行旋转
                        +=90;
                    },400);
                    }
                    =0;
                }
            }
        },
        mounted:function () {
            ();
        }
    });
</script>
</html>

scss:

.puke-tips{
  text-align: center;
  font-size: 18px;
  color: #fff;
}
.puke{
  width: 400px;
  margin: 20px auto;
  transition: transform 1s;
  transform-origin: center center 0;
  li{
    float: left;
    width: 100px;
    box-sizing: border-box;
    height: 100px;
    line-height: 100px;
    position: relative;
    div{
      transition: transform 0.4s;
      position: absolute;
      top: 0;
      left: 0;
      height: 100%;
      width: 100%;
      background: #fff;
      color: #58B7FF;
      border: 1px solid #ccc;
      font-size: 40px;
      text-align: center;
    }
    &.pukeBg{
      cursor: pointer;
      div{
        background: url("") no-repeat center,#fff;
        &:first-child{
          z-index: 1;
          transform: rotateY( 0deg);
        }
        &:last-child{
          transform: rotateY( 180deg);
        }
      }
    }
    &.pukeNum{
      div{
        &:first-child{
          transform: rotateY( 180deg);
        }
        &:last-child{
          z-index: 1;
          transform: rotateY( 0deg);
        }
      }
    }
  }

}