基于网页的一个抽奖程序

思路:网页上添加生成随机数的显示效果,从后台生成两个真正的随机数,通过ajax请求获取,然后显示在页面上

luckdraw.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ include file="/common/taglibs.jsp" %>
<html>
<head>
<title>抽奖</title>
<script type="text/javascript" src="${path}/public/js/jquery-1.7.2.min.js"></script>
<script type="text/javascript" src="${path}/public/js/script1.js"></script>
</head>
<style>

#img2{
    position:absolute;
    top:43%;
    left:10%;
    width:19%;
    height:28%;
}
#layer3{
    top:44%;
    left:36%;
    width: 30%;
    height: 12%;
}
#ResultNum{
    font-size:50pt;
    font-family:Verdana;

}
#ResultNum1{
    font-size:50pt;
    font-family:Verdana;

}
</style>
<body scroll=no>
<div id="Layer1" style="position:absolute; width: 100%; height:100%; z-index:-1">
<img  src="/public/img/luckDraw.png" height="100%" width="100%">
</div>
<div id="Layer2" style="position:absolute; width: 100%; height:100%;"  >
<img alt="" src="${path}/public/img/luckDraw_button.png" id="img2" onclick="luckDraw(this)">
</button>
</div>
<div id="Layer3" style="position:absolute;">
<div id="Resul" style="margin:0 auto;text-align:center;background:#efe;width: 100%;height:     100%;border: solid 2px #ffffff">
    <div id="Result" style="color:#40AA53">
        <span id="ResultNum">0</span>
    </div>
</div>
<div style="height: 20%"></div>
<div id="Resul1" style="margin:0 auto;text-align:center;background:#efe;width: 100%;height: 100%;border: solid 2px #ffffff">
    <div id="Result1" style="color:#40AA53">
        <span id="ResultNum1">0</span>
    </div>
</div>
</div>
</body>
<script>
var g_Timer;
var running = false;
var g_Interval = 1;
var one;
var second;
function luckDraw() {
    var url ="${path}/home/luckDraw";
    var opt = {};
//ajax异步请求数据
    $.post(url,opt,function(res){
        one = res.one;
        second = res.second;
        beginRndNum(one,second);
    })
}
</script>
</html>

引入的script1.js文件,jquery那个文件自己在网上下载

var g_Timer;
var running = false;
function beginRndNum(one,second){
if(running){
    running = false;
    clearTimeout(g_Timer);

    $('#ResultNum').css('color','red');
    $('#ResultNum1').css('color','red');
    $('#ResultNum').html(one);
    $('#ResultNum1').html(second);
    document.getElementById("img2").src="/public/img/luckDraw_button.png";
}
else{
    running = true;
    $('#ResultNum').css('color','black');
    $('#ResultNum1').css('color','black');
    document.getElementById("img2").src="/public/img/luckDraw_button2.png";
    beginTimer();
}
}

function updateRndNum(){
var num = Math.floor(Math.random()*g_PersonCount+1);
$('#ResultNum').html(num);
$('#ResultNum1').html(num);
}

function beginTimer(){
g_Timer = setTimeout(beat, g_Interval);
}

function beat() {
g_Timer = setTimeout(beat, g_Interval);
updateRndNum();
}

>后台生成随机数类
public class RandomNumber {
public HashSet<Integer> set = new HashSet<>();
public RandomNumber() {

}
public static void randomSet(int min, int max, int n, HashSet<Integer> set) {
    if (n > (max - min + 1) || max < min) {
        return;
    }
    for (int i = 0; i < n; i++) {
        // 调用Math.random()方法
        int num = (int) (Math.random() * (max - min)) + min;
        set.add(num);// 将不同的数存入HashSet中
    }
    int setSize = set.size();
    // 如果存入的数小于指定生成的个数,则调用递归再生成剩余个数的随机数,如此循环,直到达到指定大小
    if (setSize < n) {
        randomSet(min, max, n - setSize, set);// 递归
    }
}
public  HashSet<Integer> getRandomSet(int min, int max, int n){
    randomSet(min,max,n,set);
    return set;
}

}

最后剩下的就是数据的传输,根据你自己用的框架的特性,那数据传到相应位置就可以使用了

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 34,662评论 18 399
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 12,368评论 6 13
  • 原文链接 http://blog.poetries.top/2016/10/20/review-jQuery 关注...
    前端进阶之旅阅读 16,940评论 18 503
  • 一. Java基础部分.................................................
    wy_sure阅读 4,011评论 0 11
  • 又是一年升学季,每到这个时候家有娃娃的家庭就开始了东奔西跑,上个学比看病还难可到最后又获得了什么?! 今天我妈就问...
    绿非鱼阅读 272评论 0 2

友情链接更多精彩内容