js年会抽奖_公司年会用了我的抽奖程序,我竟然中奖了

临近年末,又到了各大公司举办年会的时候了。对于年会,大家最关心的应该就是抽奖了吧?虽然中奖概率通常不高,但总归是个机会,期待一下也是好的。

最近,我们部门举办了年会,也有抽奖环节。临近年会的前几天,Boss 突然找到我,说要做一个抽奖程序,部门年会要用。我当时都懵了:就三天时间,万一做的程序有bug,岂不是要被现场百十号人的唾沫给淹死?没办法,Boss 看起来对我很有信心,我也只能硬着头皮上了。

需求

  1. 要一个设置页面,包括设置奖项、参与人员名单等。
  2. 如果单个奖项中奖人数过多,可分批抽取,每批人数可设置。
  3. 默认按奖项顺序抽奖,也可选定某个奖项开始。
  4. 可删除没到场的中奖者,同时可再次抽取以作替补。
  5. 可在任意奖项之间切换,可查中奖记录名单
  6. 支持撤销当前轮次的抽奖结果,重新抽取。

实现

身为Web前端开发,自然想到用Web技术来实现。本着不重复造轮子的原则,首先求助Google,Github。搜了一圈好像没有找到特别好用的程序能直接用的。后来看到一个Github上的一个项目,用 TagCanvas 做的抽奖程序,界面挺好,就是逻辑有问题,点几次就崩溃了。代码是不能拿来用了,标签云这种抽奖形式倒是可以借鉴。于是找来文档看了下基本用法,很快就集成到页面里了。

由于设置页面涉及多种交互,纯手写太费时间了,直接用框架。平时 Element UI 用得比较多,自然就用它了。考虑到年会现场可能没有网络,就把框架相关的JS和CSS都下载到本地,直接引用。为了快速开发,也没搭建webpack构建工具了,直接在浏览器里引入JS。

                    复制代码
  1. 先设计数据结构。 奖项列表 awards
[{    "name": "二等奖",    "count": 25,    "award": "办公室一日游"}, {    "name": "一等奖",    "count": 10,    "award": "BMW X5"}, {    "name": "特等奖",    "count": 1,    "award": "深圳湾一号"}]复制代码

参与人列表 members

[{  "id": 1,  "name": "张三"}, {  "id": 2,  "name": "李四"}]复制代码

待抽奖人员列表players,是members 的子集

[{  "id": 1,  "name": "张三"}]复制代码

抽奖结果列表result,按奖项顺序索引

[[{    "id": 1,    "name": "张三"}], [{    "id": 2,    "name": "李四"}]]复制代码
  1. 设置页面 包括奖项设置和参与人员列表。
e30f44b01403477538eb430534c107b5.png
  1. 抽奖页面
435120ad1e257120c71a6f10e8b4f3f4.png

老男孩老师特别为大家准备了学习AI人工智能的干货礼包,后台私信1可获取5000G珍藏大礼包(培训视频、精选软件、内部资料)~让我们一起让IT学习更简单!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值