日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JavaScript一个简易枚举类型实现扑克牌

發布時間:2023/12/20 javascript 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JavaScript一个简易枚举类型实现扑克牌 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
<script type="text/javascript"> /*** 這個函數創建一個新的枚舉類型,實參對象表示類的每個實例的名字和值* 返回值是一個構造函數,它標識這個新類* 注意,這個構造函數也會拋出異常,不能使用它來創建該類型的新實例* 返回的構造函數包含名/值對的映射表* 包括由值組成的數組,以及以個foreach()迭代器函數*/ function enumeration(namesToValues){//這個虛擬的構造函數式返回值var enumeration = function(){throw "Can't Instantiate Enumeration"};//枚舉值繼承自這個對象var proto = enumeration.prototype = {constructor:enumeration, //標識類型toString : function(){ return this.name; }, //返回名字valueOf : function(){ return this.value;}, //返回值toJSON : function(){ return this.name; }, //轉為JSON };enumeration.values =[]; //用以存放枚舉對象的數組//現在創建新類型的實例for( name in namesToValues){ //遍歷每個值var e = Object.create(proto); //創建一個代表它的對象e.name = name ; //給它一個名字e.value = namesToValues[name]; //給它一個值enumeration[name] = e; //將它設置為構造函數的屬性enumeration.values.push(e); //將它存儲到值數組中 }//一個類方法,用來對類的實例進行迭代enumeration.foreach = function(f,c){for(var i = 0 ; i<this.values.length; i++)f.call(c,this.values[i]);};//返回表示這個新類型的構造函數return enumeration; }//枚舉類型使用示例: console.log("枚舉類型使用示例:"); var e = new enumeration({a:1,b:2,c:3}); console.log(e); console.log(e.values); e.foreach(console.log,e);//枚舉類型表示一副撲克牌: console.log("枚舉類型表示一副撲克牌:");//定義個已個表示“玩牌”的類 function Card( suit , rank ){this.suit = suit ; //每張牌都有花色this.rank = rank ; //以及點數 }//使用枚舉類定義換色和點數 Card.Suit = enumeration( {Clubs:1,Diamonds:2,Hearts : 3,Spades:4});Card.Rank = enumeration( {Two: 2, Three:3,Four: 4, Five:5,Six : 6,Seven:7,Eight:8,Nine:9,Ten:10,Jack :11,Queen:12 , King:13,Ace : 14} ) ; //定義用一描述牌面的文本 Card.prototype.toString = function(){this.rank.toString( ) + this.suit.toString(); }; //比較撲克牌中兩張牌的大小 Card.prototype.compareTo = function( that ){if(this.rank<that.rank ) return -1;if(this.rank > that.rank ) return 1;return 0; }; //以撲克牌的玩法規則對牌進行排序的函數 Card.orderByRank = function(a,b){ return a.compareTo(b)};//以橋牌的玩法規則對撲克牌進行排序的函數 Card.orderBySuit = function(a,b){if(a.suit < b.suit ) return -1;if(a.suit > b.suit ) return 1;if(a.rank < b.rank ) return -1;if(a.rank > b.rank ) return 1;return 0; };//定義用以表示一副標準撲克牌的類 function Deck(){var cards = this.cards =[]; //一副牌就是有牌組成的數組Card.Suit.foreach(function(s){ //初始化這個數組Card.Rank.foreach( function(r){ cards.push(new Card(s,r));});}); }//洗牌的方法:重新洗牌并返回洗好的牌 Deck.prototype.shuffle = function(){//遍歷數組匯總的每個元素,隨機找出牌面最小的元素,并與之(當前遍歷的元素)交換var deck = this.cards,len = deck.length;for( var i = len-1 ; i>0 ; i--){var r = Math.floor(Math.random()*(i+1)),temp; //隨機蘇temp = deck[i],deck[i] = deck[i] ,deck[r] = temp; //交換 }return this; };//發牌的方法:返回牌的數組 Deck.prototype.deal = function(n){if(this.cards.length < n ) throw "Out of cards";return this.cards.splice(this.cards.length-n,n); };Deck.prototype.toString = function(){var s = "";for( var x in this.cards){console.log(this.cards[x].suit);console.log(this.cards[x].rank);s += "{"+this.cards[x].suit.toString()+" "+this.cards[x].rank.value+"} ";}return s; };// 創建一副新撲克牌,洗牌并發牌 var deck = (new Deck()).shuffle(); var hand = deck.deal(13).sort(Card.orderBySuit); deck.toString(); console.log(deck.toString()); //console.log(hand); // console.log(hand.name);</script>

?

轉載于:https://www.cnblogs.com/ctsch/p/6915334.html

總結

以上是生活随笔為你收集整理的JavaScript一个简易枚举类型实现扑克牌的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。