怒砸 30w+ 矿石抽礼盒后,我通透了...【 幸运大转盘Vue3版】

简介: 前言大家好,我是HoMeTown。中秋节快到了,掘金社区一如既往十分贴心的在这种有意义节日里推出了社区周边的礼盒,像之前的端午粽子礼盒,这次推出了中秋月饼礼盒。

前言

大家好,我是HoMeTown

中秋节快到了,掘金社区一如既往十分贴心的在这种有意义节日里推出了社区周边的礼盒,像之前的端午粽子礼盒,这次推出了中秋月饼礼盒。

不翼而飞的矿石

满打满算,从今年的端午礼盒到现在的中秋礼盒,我最起码攒了有30w+的矿石了(海底+签到+Bug+升级奖励),但是当我打开我的余额,他却瘪成这样:

网络异常,图片无法展示
|

矿石去哪儿了?

网络异常,图片无法展示
|

矿石在这:

网络异常,图片无法展示
|

掘金一直保持初心,逢年过节推出节日性礼盒。

我也是,逢年过节疯狂的点击抽奖按钮,然而 一如既往的梭哈,一如既往的打水漂

你不是欺负老实人吗? --《让子弹飞》

在沸点看到有人抽中了,然后咱也不知道从哪儿来的自信,就觉得自己说不定也能中,想靠运气试试能不能搞一个,紧接着脑袋一热,小手一点。辛辛苦苦攒的钻石全部拜拜👋🏻。

有人说这叫赌徒心理。

借此机会,我也去搜了一下什么叫赌徒心理,同时分享给大家:

(1)只想碰运气发横财,不愿意劳动致富、创业致富;

(2)敢于孤注一掷,铤而走险,甚至不惜以生命为代价;

(3)为了达到目的,可以不择手段。

但是我感觉我这应该算不上赌徒心理?撑死应该沾点边儿吧(ps. 其实差不多)。

no pay can play

本着不想花矿石,还想玩儿的目的,我决定用Vue3自己做一个和它一样的抽奖转盘。

公平!公平!还是TMD公平! --《让子弹飞》

撸起袖子加油干

首先是排版与样式,这块没什么好说的,简单先划分一下结构:

网络异常,图片无法展示
|

定义结构:

  • lottery-container 转盘容器
  • turntable-wrap 抽奖盒子
  • border 4条边框
  • goods-container 商品容器
  • cost-wrap 操作盒子
  • btn1 单抽
  • btn2 十连抽
  • result-container 抽奖结果容器
  • mask 遮罩层
  • model 模态层

关键点在于实现的js逻辑,首先,类似这样的js逻辑,本应该放在服务端,而不应该在客户端进行处理,此处只是demo,有不对的地方望指正:

点击开始抽奖的事件:

function onStart() {
    // 设置定时器,每隔20ms做一次update操作,以达到动态切换active的目的
    let interval = setInterval(() => {
            // 此处没有用函数 winPrize是因为20ms的频率开销太大,所以仅做mock,在最后的时候更新即可
            curActive.value = Math.floor(Math.random() * 9)
    }, 20)
    // 设置延时器,结束定时操作
    let timer = setTimeout(() => {
            // 拿到最后中奖的索引
            curActive.value = winPrize(probArr.value)
            // 弹出结果层、清楚定时器 & 延时器
            showResult.value = true
            clearInterval(interval)
            clearTimeout(timer)
    }, 2000);
}
复制代码

中奖结果的概率计算,这里相对上面的逻辑来说可能比较复杂一点,但是我的这个也是比较简单版本的,我的思路是分为以下几步:

  • 获取总概率区间
  • 获取 0-总概率区间的一个随随机整数
  • 如果在当前的概率范围内,得到的就是当前概率
  • 否则减去当前的概率范围,进入下一轮循环
const goods = [
    { probability: 10, name: '随机矿石', }, 
    { probability: 10, name: '随机矿石', }, 
    { probability: 10, name: '随机矿石', }, 
    { probability: 10, name: '随机矿石', }, 
    { probability: 10, name: '随机矿石', }, 
    { probability: 50, name: 'Switch', }, 
]
// 对应各个奖项的概率,总和为100
const probArr = computed(() => {
    return goods.map(item => item.probability)
})
复制代码
function winPrize(arr) {
  let sum = eval(arr.join("+")); // 获取总概率区间
  for (let i = 0; i < arr.length; i++) {
    let random = parseInt(Math.random() * sum); // 获取 0-总概率区间的一个随随机整数
    if (random < arr[i]) {
      return i; //如果在当前的概率范围内,得到的就是当前概率
    } else {
      sum -= arr[i]; //否则减去当前的概率范围,进入下一轮循环
    }
  }
}
复制代码

十连抽的逻辑也是相同的,只是将最后的结果从单个下标换成下标的集合。


目录
相关文章
|
1天前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
102 64
|
1天前
|
JavaScript 前端开发 API
Vue 3 中 v-model 与 Vue 2 中 v-model 的区别是什么?
总的来说,Vue 3 中的 `v-model` 在灵活性、与组合式 API 的结合、对自定义组件的支持等方面都有了明显的提升和改进,使其更适应现代前端开发的需求和趋势。但需要注意的是,在迁移过程中可能需要对一些代码进行调整和适配。
|
26天前
|
存储 JavaScript 前端开发
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
【10月更文挑战第21天】 vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
|
29天前
|
API
vue3知识点:provide 与 inject
vue3知识点:provide 与 inject
34 4
vue3知识点:provide 与 inject
|
29天前
|
API
vue3知识点:readonly 与 shallowReadonly
vue3知识点:readonly 与 shallowReadonly
25 1
vue3知识点:readonly 与 shallowReadonly
|
23天前
|
JavaScript 前端开发 开发者
Vue 3中的Proxy
【10月更文挑战第23天】Vue 3中的`Proxy`为响应式系统带来了更强大、更灵活的功能,解决了Vue 2中响应式系统的一些局限性,同时在性能方面也有一定的提升,为开发者提供了更好的开发体验和性能保障。
50 7
|
24天前
|
前端开发 数据库
芋道框架审批流如何实现(Cloud+Vue3)
芋道框架审批流如何实现(Cloud+Vue3)
41 3
|
23天前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
39 1
|
23天前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
44 1
|
25天前
|
前端开发 JavaScript
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
下一篇
无影云桌面