【JS】三十行代码实现洗牌效果

/** * 创建基本卡组 * * 思路 * 1. Array.from转化基本花色字符串为数组 * 2. 利用map进行初始化花色以及基本数字, 设置level属性为排序数组做准备 * 3. [].concat()平铺数组 * @returns {Array} 返回type长度的二维数组 */const createDeck = (function(){ const t...
摘要由CSDN通过智能技术生成
/**
 * 创建基本卡组
 *
 * 思路
 * 1. Array.from转化基本花色字符串为数组
 * 2. 利用map进行初始化花色以及基本数字, 设置level属性为排序数组做准备
 * 3. [].concat()平铺数组
 * @returns {Array} 返回type长度的二维数组
 */
const createDeck = (function(){
    const type = "♠♥♦♣" // 基本花色
    const base = ["3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K", "A", "2"] // 牌组

    return [].concat(...Array.from(type, item => {
        return base.map( (v, key) => ({val: item + v, level: key}))
    }), {val: "大王", level: 13},  {val: "小王", level: 13})
})()

/**
 * 返回指定范围的随机数
 *
 * @param {number} [min] 最小值
 * @param {number} [min] 最大值
 * @returns {number} 数组下标
 */
function getRandom(min, max){
    return Math.floor(Math.random() * (max - min) + min);
}

/**
 * 生成随机卡组
 *
 * 思路
 * 1. Array.from初始化卡组长度
 * 2. 随机抽取数组元素
 * 3. 根据level属性进
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值