本文实例为大家分享了js实现抽奖的具体代码,供大家参考,具体内容如下

抽奖活动的原理还是很简单的,通过代码一目了然,如果看不懂就私聊我,可以私下交流!

方法一:使用table写一个随机抽奖

这是html+js代码

抽奖

抽奖活动

百度 腾讯 阿里 京东 华为
滴滴 蚂蚁金服 乐视 中国电网 中石化
美团 乐视 小米 网易 酷我
爱奇艺 盛大 短文学 浅墨诗韵 浪子一秋

var timer;

var button = document.querySelector("#button");

function toStart() {

// 启动定时器

if (timer == undefined) {

timer = setInterval(changeStyle, 100);

button.setAttribute("value", "停止");

} else {

clearInterval(timer);

timer = undefined;

button.setAttribute("value", "开始");

}

}

// 改变样式

var a, b;

function changeStyle() {

var tb = document.querySelector("table");

console.log(a);

if (a != undefined) {

tb.rows[a].cells[b].style.backgroundColor = "white";

}

//

// 获取要操作的元素

a = parseInt(Math.random() * 4);

b = parseInt(Math.random() * 5);

// console.log(a);

var col = tb.rows[a].cells[b];

col.style.backgroundColor = "red";

}

方法二:使用span标签写

html+js代码如下

抽奖

抽奖活动

// 获取要操作的元素

var div = document.getElementById("body");

// 动态添加span

for (var i = 0; i < 25; i++) {

// 创建一个新的标签

var el = document.createElement("span");

// 给标签设置内容

el.innerText = i;

// 添加子元素

div.appendChild(el);

}

var timer;

var button = document.querySelector("#button");

function toStart() {

// 启动定时器

if (timer == undefined) {

timer = setInterval(changeStyle, 100);

button.setAttribute("value", "停止");

} else {

clearInterval(timer);

timer = undefined;

button.setAttribute("value", "开始");

}

}

// 改变样式

var selection;

function changeStyle() {

var spans = document.getElementsByTagName("span");

if (selection != undefined) {

console.log(selection);

spans[selection].style.backgroundColor = "white";

}

selection = parseInt(Math.random() * 25);

var spans = document.getElementsByTagName("span");

var selectSpan = spans[selection];

selectSpan.style.backgroundColor = "red";

}

两个页面的css代码

*{

margin: 0;

padding: 0;

}

body{

display: block;

}

.content{

width: 500px;

margin: auto;

}

.top{

text-align: center;

height: 50px;

color: red;

font-size: 30px;

}

table{

width: 100%;

border: 1px solid red;

border-spacing: 0;

}

th{

border: 1px dashed rgb(189, 189, 86);

height: 40px;

}

.bottom{

height: 50px;

margin-top: 20px;

text-align: center;

}

.button{

background-color: #4CAF50; /* Green */

border: none;

color: white;

padding: 15px 32px;

text-align: center;

text-decoration: none;

display: inline-block;

font-size: 16px;

}

/* test2-1 */

.body{

width: 512px;

height: 260px;

border: 1px solid red;

}

span{

display: inline-block;

width: 100px;

height: 50px;

border: 1px dashed #b1da1f;

line-height: 50px;

text-align: center;

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

html抽奖怎么重置,js实现抽奖的两种方法相关推荐

  1. 简易的js获取星期几的两种方法

    第一种: var a = ["日", "一", "二", "三", "四", "五&quo ...

  2. js阻止冒泡的两种方法

    冒泡是一种很有意思的现象,在我们的 js 中也有冒泡现象,让我们一起去看看吧 先来看一段代码 <!DOCTYPE html> <html><head><met ...

  3. js 实现trim()的两种方法

    方法一: function fn(str){var n = [];var strr = str.split('').reverse().join('');n = str.split('');for(v ...

  4. js生成随机颜色的两种方法

    1.rgb颜色生成 function rgb(){//rgb颜色随机const r = Math.floor(Math.random()*256);const g = Math.floor(Math. ...

  5. JS实现合并单元格的两种方法

    本后端菜狗想在网上找合并单元格的代码,结果找到的都是太老的代码,然后就只能用Js手写了两种方法(第二种方法叫了个前端大佬写的) 废话不多说,直接上代码: (由于时间有点小久,就不写思路和过程啦) 第一 ...

  6. 基于ArcGIS JS API实现的两种距离和面积测量方式

    文章目录 前言 开发思路 主要代码 效果测试 效果图 测试页面 开发总结 参考链接 前言 在一些地图地图应用中,距离.面积测量属于基础功能.ArcGIS API for JavaScript有单独提供 ...

  7. 防止email被抓取的两种方法(js和css)

    现在很多无聊人士都用自己的spider在网上到处抓取email, 如果你的页面上写了自己的email,那么不多久就会收到很多垃圾邮件. 有很多方法可以避免被抓取,现在很多人都把@换成#,不过估计很多蜘 ...

  8. js数组去重的四种方法

    四种算法来实现这个目的: Array.prototype.unique1 = function () {var n = []; //一个新的临时数组for (var i = 0; i < thi ...

  9. iOS: JS和Native交互的两种方法,iosjsnative交互

    iOS: JS和Native交互的两种方法,iosjsnative交互 背景: UIWebView: iOS 用来展示 web 端内容的控件. 1. 核心方法: - (NSString*)string ...

最新文章

  1. 看一个穷人怎样拥有多套房产的?-财富可以这样成长
  2. 数据库 DB database SQL DBMS
  3. 【免费报名】与阿里云一同探索视频云的新技术与新场景
  4. mysql函数lead用指定的字符串实现左填充指定长度
  5. php获取特殊标签,thinkphp特殊标签使用
  6. 微信小程序中form 表单提交和取值实例详解
  7. ftp改为sftp_浅谈 FTP、FTPS 与 SFTP
  8. python求出五位数的回文数_python之递归
  9. 寻找是生命中的另一场迷失
  10. sublime text3设置空格和tab键
  11. 协议圣经 RTSP(三)
  12. php表格打印输出,PHP输出表格
  13. sort的排序及使用
  14. 如何阅读《深入理解计算机系统》这本书?
  15. Recorder.js HTML5+JS实现网页录音
  16. 数据库异常用户sa登录失败_轻松解决SQLserver2014出现“用户sa登录失败 错误18456”的问题-网络教程与技术 -亦是美网络...
  17. 敌兵布阵——线段树单点修改区间查询
  18. 河南大学大计算机考研复试分数线预测,2017年河南大学考研复试分数线以及复试通知...
  19. 大厂的区块链之路|蚂蚁金服怎么玩?
  20. Mac 使用brew 安装adb

热门文章

  1. ZXCK在线翻译效果截图
  2. 我的这两年-IT小硕
  3. Windows API 理解----Nt* Zw*
  4. 用L298驱动直流减速电机
  5. rabbitmq简介及安装
  6. 一个计算机爱好者的不完整回忆(三十九)破解ACCESS数据库
  7. Fluke SimpliFiber Pro FTK1475做光纤损耗测试
  8. Mac中Carthage的安装和使用
  9. ION-DTN网络设计思想(一)
  10. 第二次打开不是最大_舵手图解:大盘日线第二次形成买点信号