国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > 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>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 晋州市| 石渠县| 蒙山县| 南木林县| 濉溪县| 邹城市| 承德县| 南雄市| 定边县| 法库县| 淅川县| 荔波县| 蒙自县| 高州市| 松原市| 霸州市| 洛隆县| 宁强县| 资源县| 郯城县| 昌黎县| 织金县| 南漳县| 玉田县| 乌拉特中旗| 海阳市| 绿春县| 镇雄县| 普洱| 伊吾县| 江城| 璧山县| 晴隆县| 莲花县| 内黄县| 微博| 罗定市| 游戏| 泰州市| 诸城市| 文水县|