被黑心商家坑了N次,探究抽奖背后的秘密 —— H5转盘小游戏完整实现(源码直接拿走)

body, a, h1, h2, h3, h4, h5, h6, ul, li, dl, dt, article, section, div, p, header, footer, menu, input, img{

margin: 0;

padding: 0;

}

img{

vertical-align: middle;

}

p, h1, h2, h3, h4, h5, h6,ul{

-webkit-margin-before: 0;

-webkit-margin-after: 0;

-webkit-padding-start: 0;

-moz-margin-before: 0;

-moz-margin-after: 0;

-moz-padding-start: 0;

-moz-padding-end: 0;

}

/* clear float */

.clearfix:after {

content:“”;

display: block;

clear:both;

}

/* Responsive Layout */

li{

list-style: none;

}

a{

text-decoration: none;

}

input{

-webkit-appearance: none;

}

input:focus{

outline: none;

}

header{

height: .88rem;

border-bottom: 1px solid #ccc;

background-color: #fff;

}

.header-back{

width: .36rem;

height: .36rem;

float: left;

margin-top: .27rem;

margin-left: .28rem;

}

.header-title{

float: left;

font-weight: 600;

width: 90%;

font-size: .36rem;

color: #333;

text-align: center;

line-height: .88rem;

}

.container{

font-size: 24px;

text-align: center;

padding-top: 50px;

}

.lottery{

font-size: .32rem;

width: 6rem;

height: 6rem;

margin: .2rem auto;

display: flex;

display: -webkit-flex;

flex-wrap: wrap;

border: 1px solid #000;

}

.item{

width: 2rem;

height: 2rem;

line-height: 2rem;

color: orangered;

font-weight: bold;

text-align: center;

border: 1px solid orangered;

box-sizing: border-box;

background-size: 100%;

}

.active{

background: #ffe6cc;

}

button:focus{

outline: none;

}

.lottery-item-0{

background-image: url(‘…/img/huawei.png’);

}

.lottery-item-1{

background-image: url(‘…/img/iphone.jpg’);

}

.lottery-item-4{

background-image: url(‘…/img/xiaomi.jpg’);

}

.lottery-item-7{

background-image: url(‘…/img/xiaoxiong.jpg’);

}

.lottery-item-3{

background-image: url(‘…/img/xiaodu.jpg’);

}

.lottery-item-6{

background-image: url(‘…/img/dfs.jpg’);

}

.lottery-item-5{

background-image: url(‘…/img/bingxiang.jpg’);

}

2. 工具函数(用于调整概率)


  • 此工具函数传入一个二维数组,用于调整概率

  • 默认商品概率相同,调用的时候 randomNum() 时候不传参数即可

  • 也可以自由设置概率

function randomNum(arr){

// 1. 容错处理

arr = arr || [];

// ES6 Map对象: 键与值的集合 方便访问其键与值

let m = new Map(arr);

// 计算概率

let probability = 0;

// console.log(m.values())

for (const i of m.values()) {

probability += i;

}

if(probability > 1){

// 给一个友好的提示

alert(“概率总和不能大于1,小学数学是体育老师教的???”);

return false;

}

// 剩下没有定义的各自能占多少概率。

// size 返回映射中的元素数

let remainProbability = (1 - probability) / (8 - m.size);

console.log(remainProbability)

// 生成随机值,跟i对应的概率比较,

let res = 0, r = Math.random();

for (let i = 0; i < 8; i++) {

// 有就取值 没有就随机取

m.has(i) ? res += m.get(i) : res += remainProbability;

// console.log("res= "+ res);

// console.log("r= "+ r);

if (res > r) {

return i;

}

}

}

在这里插入图片描述

3. 传参及接收值配置


let step = 0, //计数器

timeInterval = 2, //速度控制器

final, //最终位置

looperFun, // setTimeout的返回值

prizeList = [‘华为’, ‘iPhone X’, ‘谢谢惠顾’, ‘小度音响’, ‘手环’, ‘格力冰箱’, ‘电风扇’, ‘小熊抱枕’];

// 开始游戏

function start(e){

if(e.target.dataset.able === “1”){

// 随机0-7

// 设置抽奖概率 不传参的话这几个商品几率相等

// let arr = [[0,0],[1,0.5],[2,0],[3,0],[4,0],[5,0],[6,0],[7,0]];

// final = randomNum(arr);

final = randomNum(); // 这里不传参 概率均等

console.log(final);

if(final === false){

console.log(“出错了”);

return false;

}

e.target.setAttribute(‘data-able’, 0);

looperFun = setTimeout(looper, 100);

}else{

console.log(“什么垃圾玩意,点不了”);

return false;

}

}

  • 传参的二维数组第一个值代表商品id,第二个值为分配的概率

// 设置抽奖概率 不传参的话这几个商品几率相等

// let arr = [[0,0],[1,0.5],[2,0],[3,0],[4,0],[5,0],[6,0],[7,0]];

总结

谈到面试,其实说白了就是刷题刷题刷题,天天作死的刷。。。。。

为了准备这个“金三银四”的春招,狂刷一个月的题,狂补超多的漏洞知识,像这次美团面试问的算法、数据库、Redis、设计模式等这些题目都是我刷到过的

并且我也将自己刷的题全部整理成了PDF或者Word文档(含详细答案解析)

我的美团offer凉凉了?开发工程师(Java岗)三面结束等通知...

66个Java面试知识点

架构专题(MySQL,Java,Redis,线程,并发,设计模式,Nginx,Linux,框架,微服务等)+大厂面试题详解(百度,阿里,腾讯,华为,迅雷,网易,中兴,北京中软等)

我的美团offer凉凉了?开发工程师(Java岗)三面结束等通知...

算法刷题(PDF)

我的美团offer凉凉了?开发工程师(Java岗)三面结束等通知...

谈到面试,其实说白了就是刷题刷题刷题,天天作死的刷。。。。。

为了准备这个“金三银四”的春招,狂刷一个月的题,狂补超多的漏洞知识,像这次美团面试问的算法、数据库、Redis、设计模式等这些题目都是我刷到过的

并且我也将自己刷的题全部整理成了PDF或者Word文档(含详细答案解析)

[外链图片转存中…(img-B02lE6jo-1720128615854)]

66个Java面试知识点

架构专题(MySQL,Java,Redis,线程,并发,设计模式,Nginx,Linux,框架,微服务等)+大厂面试题详解(百度,阿里,腾讯,华为,迅雷,网易,中兴,北京中软等)

[外链图片转存中…(img-HtblHH35-1720128615855)]

算法刷题(PDF)

[外链图片转存中…(img-7k2hQZb6-1720128615855)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值