亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript實例--教你實現撲克牌洗牌功能

2019-11-20 15:21:43
字體:
來源:轉載
供稿:網友

我們一般都會按照順序把隨機摸過來的牌從小到大的順序在手上理整齊(記得小時候打牌兩副牌手都抓不過來),這篇隨筆就是想通過實現這個功能來熟悉下js中排序數組等相關知識。

用到知識點:

1.工廠方式創建對象

2.js數組sort()方法

復制代碼 代碼如下:

  var testArr = [1, 3, 4, 2];
     testArr.sort(function (a,b) {
         return a - b;
     })
     alert(testArr.toString());//1,2,3,4
     testArr.sort(function (a, b) {
         return b- a;
     })
     alert(testArr.toString());//4,3,2,1

3.js-Math.radom()隨機數

Math.random();//0-1 取得的隨機數大于等于0且小于1

4.js數組splice用法

復制代碼 代碼如下:

//第一個參數是插入的起始位置
//第二個參數是從起始位置開始刪除元素的個數
//第三個參數是在起始位置開始插入的元素  
//例子
var testArr = [1, 3, 4, 2];
testArr.splice(1, 0, 8);
alert(testArr.toString());//1,8,3,4,2

var testArr1 = [1, 3, 4, 2];
testArr1.splice(1, 1, 8);
alert(testArr1.toString());//1,8,3,4,2

5.js數組shift用法

復制代碼 代碼如下:

    //取出數組中的首個元素返回,數組刪除第一個元素
   //例子
    var testArr = [1, 3, 4, 2];
     var k=  testArr.shift();
     alert(testArr.toString());//3,4,2
     alert(k);//1

有了這些基礎知識,咱們可以開始打牌了,假設就一個人摸牌,底牌是隨機的,我們每次摸來一張牌的時候就要把他插到手上的牌中,保證順序是從小到大!

第一步:首先我們要寫一個生產撲克牌對象的方法:

復制代碼 代碼如下:

/*工廠模式創建各種牌
*number:牌上的數字
*type:牌的花色
*/
var Cards = (function () {
var Card = function (number, type) {
this.number = number;
this.type = type;
}
return function (number, type) {
return new Card(number, type);
}
})()

第二步:創建撲克牌,洗牌,存儲

復制代碼 代碼如下:

    var RadomCards = [];//隨機牌存儲數組
    var MyCards = [];//存儲摸過來的牌

 
    //花色0-黑桃 1-梅花 2-方塊  3-紅桃 4-大鬼  5-小鬼
    //數值0-13代表 鬼,1,2,3,4,5,6,7,8,9,10,J,Q,K;
    function CreatCompeleteCard() {
        var index = 2;
        var arr = [];
        for (var i = 0; i <= 13; i++) {
            if (i == 0) {
                arr[0] = new Cards(i, 4);
                arr[1] = new Cards(i, 5);
            } else {
                for (var j = 0; j <= 3; j++) {
                    arr[index] = new Cards(i, j);
                    index++;
                }
            }
        }
        RadomCards = SortCards(arr);
        Show();//在頁面上顯示當前的牌
    }
    //洗牌
    function SortCards(arr) {
        arr.sort(function (a, b) {
            return 0.5 - Math.random();
        })
        return arr;
    }

第三步:開始摸牌,摸牌的時候我們首先要判斷插入的位置,然后把新牌插入到指定位置,形成新的整齊的順序

復制代碼 代碼如下:

//摸牌方法
    function GetCards(CardObj) {
        var k = InCardsIndex(MyCards, CardObj);//考慮下插入的位置
        MyCards.splice(k, 0, CardObj); // 插入形成新的順序
    }
    /*【獲取牌應該插入的位置】
     *arr:當前手里的牌
     *obj:新摸到的牌
     */
    function InCardsIndex(arr, obj) {
        var len = arr && arr.length || 0;
        if (len == 0) {
            return 0;
        }else if (len == 1) {
            if (obj.number >= arr[0].number) {
                return 1;
            } else {
                return 0;
            }
        } else {
            var backi = -1;
            for (var i = 0; i < len; i++) {

                if (obj.number <= arr[i].number) {
                    backi = i;
                    break;
                }
            }
            if (backi == -1) {
                backi = len;
            }
            return backi;
        }
    }

好啦!通過html上的button按鈕出發Start來摸牌,點一次摸一張牌!并展示出來

復制代碼 代碼如下:

  function Start() {//摸牌方法,一次摸一張
        if (RadomCards.length > 0) {
            GetCards(RadomCards.shift());
            Show();
        } else {
            alert("沒有了");
        }
    }
//該show方法是用來在頁面展示當前牌的動向
    function Show() {
        var lenOld = RadomCards.length;
        var lenNew = MyCards.length;
        var html = "";
        for (var i = 0; i < lenOld; i++) {
            html += "<div class='pai'><b>" + RadomCards[i].type + "</b>-<div class='nu'>" + RadomCards[i].number + "</div></div>";
        }
        document.getElementById("old").innerHTML=html;
        html = "";
        for (var i = 0; i < lenNew; i++) {
            html += "<div class='pai new'><b>" + MyCards[i].type + "</b>-<div class='nu'>" + MyCards[i].number + "</div></div>";
        }
        document.getElementById("new").innerHTML=html;
    }

上html和css的代碼

復制代碼 代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
    <meta http-equiv="content-type" content="text/html;charset=utf-8" />
    <style type="text/css">
        .boom{
            width: 50px;
            height: 50px;
            border: solid 1px red;
            position: absolute;
            top: 5px;
            left: 5px;
        }
        .pai
        {
            width: 50px;
            height: 100px;
            border: solid 1px red;
            margin-left: 3px;
            float: left;
        }
        .new
        {
            border: solid 1px blue;
        }
        .nu
        {
            text-align:center;
            font-size:24px;
            margin-top:25px;        
        }
    </style>
</head>
<body>
    <!-- <div class="boom"></div>-->
    <input type="button" value="開始" onclick="CreatCompeleteCard()" />
    <input type="button" value="摸牌" onclick="Start()" />
    <br/>
    底牌:<div id="old"></div>
    <div style="clear: both"></div>
    <hr />
    我摸到的牌:<div id="new"></div>
</body>
</html>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
美女啪啪无遮挡免费久久网站| 中文字幕日韩免费视频| 亚洲免费av片| 国产精品精品视频一区二区三区| 亚洲级视频在线观看免费1级| 亚洲国产精品人人爽夜夜爽| 成人免费网站在线观看| 欧美成人精品一区二区三区| 日韩一区二区av| 欧美激情亚洲综合一区| 亚洲自拍偷拍区| 久久久噜噜噜久噜久久| 日韩风俗一区 二区| 亚洲一区二区中文字幕| 日韩欧美黄色动漫| 国产成人精品电影| 中文字幕久精品免费视频| 国产福利成人在线| 午夜精品久久久久久久99黑人| 日韩综合中文字幕| 亚洲精品98久久久久久中文字幕| 亚洲欧美中文另类| 亚洲欧美日韩天堂一区二区| 揄拍成人国产精品视频| 日韩电影免费在线观看中文字幕| 久久精品国产清自在天天线| 欧美美女15p| 国产一区二区三区视频免费| 色哟哟网站入口亚洲精品| 久久久久免费视频| 亚洲va欧美va国产综合剧情| 精品免费在线观看| 亚洲一区二区在线| 亚洲欧美另类自拍| 日韩精品在线电影| 国产成人精品免费久久久久| 麻豆国产精品va在线观看不卡| 欧美中文在线免费| 中文字幕亚洲国产| 国产精品私拍pans大尺度在线| 亚洲欧美一区二区三区在线| 91禁外国网站| 北条麻妃一区二区在线观看| 午夜精品一区二区三区视频免费看| 91夜夜未满十八勿入爽爽影院| 精品国产一区二区三区在线观看| 欧美大人香蕉在线| 国产精欧美一区二区三区| 久久在精品线影院精品国产| 久久影院在线观看| 亚洲香蕉av在线一区二区三区| 俺去啦;欧美日韩| 青青青国产精品一区二区| 中文字幕在线精品| 91精品国产91久久久久久| 国产精品免费看久久久香蕉| 51精品在线观看| 成人黄色av网站| 色琪琪综合男人的天堂aⅴ视频| 欧美精品精品精品精品免费| 美日韩精品免费观看视频| 日韩av电影院| 国产主播精品在线| 欧美精品www在线观看| 欧美激情国内偷拍| 亚洲精品一区二区三区婷婷月| 日韩av在线免费观看一区| 欧美专区在线播放| 国产精品视频免费在线观看| 成人久久18免费网站图片| 精品国产拍在线观看| 亚洲欧美中文日韩v在线观看| 日韩亚洲第一页| 丁香五六月婷婷久久激情| 欧美中文在线视频| 97香蕉超级碰碰久久免费软件| 成人av在线亚洲| 久久久久久中文字幕| 日韩欧美a级成人黄色| 福利一区福利二区微拍刺激| 97久久伊人激情网| 精品久久久中文| 69久久夜色精品国产7777| 亚洲精品丝袜日韩| 亚洲天堂男人天堂女人天堂| 丝袜亚洲欧美日韩综合| 7m第一福利500精品视频| 日韩电影在线观看永久视频免费网站| 亚洲国产精品999| 久久精品国产91精品亚洲| 在线观看不卡av| 国产国语videosex另类| 亚洲级视频在线观看免费1级| 成人国产精品免费视频| 欧美午夜美女看片| 国产精品69久久| 亚洲国产一区二区三区四区| 国产精品一区二区三区免费视频| 久久精品视频播放| 日韩在线观看免费网站| 国语自产精品视频在线看| 日韩精品免费电影| 亚洲精品国产福利| 色综合伊人色综合网| 日韩视频免费在线| 国产91在线高潮白浆在线观看| 日韩在线视频免费观看高清中文| 国产免费亚洲高清| 深夜精品寂寞黄网站在线观看| 日韩精品丝袜在线| 国产精品久久久久久久久久尿| 亚洲人在线视频| 91啪国产在线| 国产成人91久久精品| 精品女厕一区二区三区| 国产免费一区二区三区香蕉精| 日韩精品在线观看网站| 亚洲精品aⅴ中文字幕乱码| 亚洲综合在线播放| 欧美性xxxxx极品| 国产视频久久久久| 88国产精品欧美一区二区三区| 亚洲直播在线一区| 久久精品成人欧美大片古装| 亚洲欧美一区二区精品久久久| 亚洲www在线| 国产精品一区二区av影院萌芽| 久久久久国产一区二区三区| 亚洲国产天堂网精品网站| 亚洲一区二区三区在线免费观看| 人九九综合九九宗合| 乱亲女秽乱长久久久| 国产日韩欧美电影在线观看| 亚洲国产精品久久久| 91精品国产免费久久久久久| 欧美日韩国产va另类| 国产精品久久久久久久久久ktv| 久久视频在线观看免费| 自拍偷拍亚洲一区| 91在线免费视频| 在线看片第一页欧美| 九九热这里只有精品6| 亚洲国产精彩中文乱码av在线播放| 伊人伊成久久人综合网站| 国产精品露脸av在线| 国产日韩av在线| 国产精品va在线播放我和闺蜜| 97视频在线观看亚洲| 中文字幕无线精品亚洲乱码一区| 国外成人免费在线播放| 久久精品国亚洲| 国产精品99一区| 中文字幕精品—区二区| 国产成人一区二区在线| 日韩成人在线观看| 日本精品免费一区二区三区| 亚洲国产成人精品电影| 日韩av在线免费观看| 日本亚洲欧洲色α| 国产精品久久久久91| 国产精品人成电影在线观看| 欧美激情综合亚洲一二区| 国产一区二区在线免费视频| 日韩精品在线第一页|