//实现枚举类型,扑克牌应用
function creatEnum(p){
//构造函数
var Enumeration = function(){throw 'can not Instantiate Enumerations';};
//重写原型并将原型赋值给变量proto
var proto = Enumeration.prototype = {
constructor:Enumeration,
toString:function(){return this.name;},
valueOf:function(){return this.value;},
toJSON:function(){return this.name;}
};
//添加类属性,方法
Enumeration.values = [];
for(var n in p){ //将对象p的每个元素都单独转存到一个单独的对象o里面,并将这些对象o存入类属性values数组中
var o = Object.create(proto); //对象o继承了Enumeration的3个实例方法和构造函数
Enumeration.prototype.valueOf = function(){return this.value*1;}; //重写原型的valueof方法
o.name = n;
o.value = p[n];
Enumeration[n] = o; //添加类属性name,值为对象o
Enumeration.values.push(o);
}
Enumeration.foreach = function (f,c) {
for(var i =0;i<this.values.length;i++){
f.call(c,this.values[i]);
}
};
return Enumeration;
}
//===
var Coin = creatEnum( {Penny:1,Nickel:5,Dime:10,Quarter:25} );
console.log(Coin);
/*结果:枚举对象Coin
{ [Function]
values:
[ { [Number: 10] name: 'Penny', value: 1 },
{ [Number: 50] name: 'Nickel', value: 5 },
{ [Number: 100] name: 'Dime', value: 10 },
{ [Number: 250] name: 'Quarter', value: 25 } ],
Penny: { [Number: 10] name: 'Penny', value: 1 },
Nickel: { [Number: 50] name: 'Nickel', value: 5 },
Dime: { [Number: 100] name: 'Dime', value: 10 },
Quarter: { [Number: 250] name: 'Quarter', value: 25 },
foreach: [Function] }
*/
console.log(Coin.Dime+2); //102 Coin.Dime本身继承自枚举对象,继承并修改了valueof方法用来将value转化为数字做计算
//===使用函数creatEnum()来表示一副54张的扑克牌==
function Card(suit,rank){
this.suit = suit;
this.rank = rank;
}
Card.Suit = creatEnum( {Clubs:1,Diamonds:2,Heates:3,Spades:4,Joker:5} );
Card.Rank = creatEnum( {Three:3,Four:4,Five:5,Six:6, Seven:7,Eight:8,Nine:9,Ten:10,
Jack:11,Queen:12,King:13,Ace:14,Two:15,SmallJoker:16,BigJoker:17} );
Card.prototype.toString = function(){
return this.rank.toString() +' of '+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.orderBySuit = function(a,b){
if(a.suit< b.suit) return -1;
if(a.suit> b.suit) return 1;
return 0;
};
Card.orderByRank = function(a,b){
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){ //对每个花色执行
if(s!=5) {
Card.Rank.foreach(function (r) {
if (r != 16 && r != 17) {
cards.push(new Card(s, r));
}
});
}else{
Card.Rank.foreach(function (r){
if(r == 16) cards.push(new Card(s, r));
if(r == 17) 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[r], 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);
};
//开始:
var deck = new Deck();
var deck1 =deck.shuffle();
var n = 17;
var hand1 = deck1.deal(n).sort(Card.orderByRank);
for(var i = 0;i<n;i++){
var body = document.getElementById('body');
var div = document.createElement('div');
div.style.width = '50px';
div.style.height = '100px';
div.style.border = '1px solid gray';
div.style.float = 'left';
div.innerHTML = hand1[i].suit.name+' '+hand1[i].rank.name;
body.appendChild(div);
console.log(hand1[i].suit.name+' '+hand1[i].rank.name);
}
- JavaScript 学习笔记: 扩充类型的功能
JavaScript 是允许给基本类型扩充功能的.例如,可以通过对Object.prototype增加方法,可以让该方法对所有的对象都可用. 这样的方式对函数,数组,字符串,数字,正则表达式和布尔值同 ...
- effective-java学习笔记---使用枚举类型替代整型常量34
1.要将数据与枚举常量相关联,请声明实例属性并编写一个构造方法,构造方法带有数据并将数据保存在属性中. // Enum type with data and behavior public enum ...
- Swift 学习笔记 enum 枚举类型
异端,异端啊,我感觉这是map吧? enum ATMStatus { case Success(Int) case Error(String) } func withdraw(amount: Int) ...
- javascript学习笔记(四) Number 数字类型
数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数 toExponential() 方法 用科学 ...
- Java程序猿的JavaScript学习笔记(9—— jQuery工具方法)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿的JavaScript学习笔记(8——jQuery选择器)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿JavaScript学习笔记(2——复制和继承财产)
计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...
- Java程序猿JavaScript学习笔记(4——关闭/getter/setter)
计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...
- CLR_Via_C#学习笔记之枚举
CLR_Via_C#学习笔记之枚举 枚举类型(Enum)定义的一组"符号名称/值"配对:因为枚举类型使用程序更容易编写.阅读和维护,而且它是强类型: 枚举是值类型:由System. ...
随机推荐
- hdu Caocao's Bridges(无向图边双连通分量,找出权值最小的桥)
/* 题意:给出一个无向图,去掉一条权值最小边,使这个无向图不再连同! tm太坑了... 1,如果这个无向图开始就是一个非连通图,直接输出0 2,重边(两个节点存在多条边, 权值不一样) 3,如果找到 ...
- 《BI那点儿事》Microsoft 决策树算法——找出三国武将特性分布,献给广大的三国爱好者们
根据游戏<三国志11>武将数据,利用决策树分析,找出三国武将特性分布.其中变量包括统率.武力.智力.政治.魅力.身分.变量说明:统率:武将带兵出征时的部队防御力.统帅越高受到普通攻击与兵法 ...
- 如何安装Oracle Instant Client
Oracle Instant Client是Oracle发布的轻量级数据库客户端,下面我们来看看官方的定义: Instant Client allows you to run your applica ...
- Java多线程系列--“基础篇”10之 线程优先级和守护线程
概要 本章,会对守护线程和线程优先级进行介绍.涉及到的内容包括:1. 线程优先级的介绍2. 线程优先级的示例3. 守护线程的示例 转载请注明出处:http://www.cnblogs.com/skyw ...
- 使用 jQuery & CSS3 实现翻转的作品集滑块
作为 Web 开发人员,我想你一定见过各种各样的图片滑块效果.展示产品或者个人作品的方法有很多,其中之一是使用网格样式的滑块效果.在本教程中,我将分享如何使用 jQuery 和 CSS3 变换实现翻转 ...
- Android反编译(三)之重签名
Android反编译(三) 之重签名 [目录] 1.原理 2.工具与准备工作 3.操作步骤 4.装X技巧 5.问题 1.原理 1).APK签名的要点 a.所有的应用程序都必须有数字证书 ,Androi ...
- SQL Server代理(3/12):代理警报和操作员
SQL Server代理是所有实时数据库的核心.代理有很多不明显的用法,因此系统的知识,对于开发人员还是DBA都是有用的.这系列文章会通俗介绍它的很多用法. 如我们在这个系列的文章里所见,SQL Se ...
- 原生js实现简洁的返回顶部组件
本文内容相当简单,所以没有发布到博客园首页,如果你不幸看到,那只能是我这篇文章的荣幸,谢谢你的大驾光临~(本博客返回顶部的功能就使用的是这个组件) 返回顶部组件是一种极其常见的网页功能,需求简单:页面 ...
- c# 打开指定的网址
System.Diagnostics.Process.Start(url);
- WPF系列:无边框窗口
<Window x:Class="Ares.Animations.Window3" xmlns="http://schemas.microsoft.com/winf ...