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’);
}
-
此工具函数传入一个二维数组,用于调整概率
-
默认商品概率相同,调用的时候 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;
}
}
}
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文档(含详细答案解析)
66个Java面试知识点
架构专题(MySQL,Java,Redis,线程,并发,设计模式,Nginx,Linux,框架,微服务等)+大厂面试题详解(百度,阿里,腾讯,华为,迅雷,网易,中兴,北京中软等)
算法刷题(PDF)
谈到面试,其实说白了就是刷题刷题刷题,天天作死的刷。。。。。
为了准备这个“金三银四”的春招,狂刷一个月的题,狂补超多的漏洞知识,像这次美团面试问的算法、数据库、Redis、设计模式等这些题目都是我刷到过的
并且我也将自己刷的题全部整理成了PDF或者Word文档(含详细答案解析)
[外链图片转存中…(img-B02lE6jo-1720128615854)]
66个Java面试知识点
架构专题(MySQL,Java,Redis,线程,并发,设计模式,Nginx,Linux,框架,微服务等)+大厂面试题详解(百度,阿里,腾讯,华为,迅雷,网易,中兴,北京中软等)
[外链图片转存中…(img-HtblHH35-1720128615855)]
算法刷题(PDF)
[外链图片转存中…(img-7k2hQZb6-1720128615855)]