js框架jquery实现幸运大转盘抽奖程序代 概率怎么算的

JavaScript025

js框架jquery实现幸运大转盘抽奖程序代 概率怎么算的,第1张

原理上,由php生成一个随机数,然后ajax取得这个数,通过这个数,来显示给用户。 如果你要“转”起来,js还是比较麻烦的,你可以考虑用flash.因为js是无法操作图片的旋转度的。 当然,可以用一些其他方法模拟一下,有难度。

一款JS+html5转盘抽奖代码网页特效,该特效代码基于html5 canvas技术实现,点击开始旋转按钮,转盘就会快速旋转,停止旋转后,所在区域就是中奖项目。奖项可以自定义。请用支持HTML5+CSS3主流浏览器预览效果。(兼容测试:FireFox、Chrome、Safari、Opera等支持HTML5/CSS3浏览器)

使用方法:

1、调用CSS样式:

<link rel="stylesheet" type="text/css" href="css/style.css" />

2、添加HTML代码:

将<!--效果html开始-->......<!--效果html结束-->之间的html和js代码;放在<body></body>之间。

获取id   ${user.id}

获取name ${user.name}

获取company ${user.company}

JS中直接从java后台获得对象的值(数组的值)

这里举得例子是:JS直接从后台Contorller中(SpringMVC中的model中)获得数值的值

Contorller 此处将 talentIntegralRecordsDay talentIntegralRecordsIntegral 两个数组用JSON.toJSONString()封装。

@SuppressWarnings("deprecation")

@RequestMapping("/integralParadise")    public ModelAndView Welcome(HttpServletRequest request){

Users user = userService.currentUser(request) 

user.getTalentUser().getIntegral()

System.out.println(user.getTime().getDate())

TalentIntegralRecord[] signInTalentIntegralRecords= wechatIntegralService.getUserSignInTalentIntegralRecords(user.getId())       int size = signInTalentIntegralRecords.length       int[] talentIntegralRecordsDay = new int[size]

Long[] talentIntegralRecordsIntegral = new Long[size]       for(int i=0i<signInTalentIntegralRecords.lengthi++){

talentIntegralRecordsDay[i]=signInTalentIntegralRecords[i].getOperatorTime().getDate()

talentIntegralRecordsIntegral[i]=signInTalentIntegralRecords[i].getIntegral()

}

Map<String,Object>map = new HashMap<String,Object>()

map.put("talentIntegralRecordsDay", JSON.toJSONString(talentIntegralRecordsDay))

map.put("talentIntegralRecordsIntegral", JSON.toJSONString(talentIntegralRecordsIntegral))       return new ModelAndView("wechat/integralParadise/rili",map)

}

前台JSP 因为用到两个数组数据的JS代码为页面引用的JS代码所以要在页面中先声明获得后台两个数组(这段JS代码应在引用的JS文件前面)

<script type="text/javascript">

$(document).ready(function(){

window.talentIntegralRecordsDay = ${talentIntegralRecordsDay}

window.talentIntegralRecordsIntegral = ${talentIntegralRecordsIntegral}

})</script>

引用的JS文件 开始就获得了两个数组的值

$(function() {    var signFun = function() {      

var dateArray = window.talentIntegralRecordsDay// 假设已经签到的

var talentIntegralRecordsIntegral = window.talentIntegralRecordsIntegral       var $dateBox = $("#js-qiandao-list"),

$currentDate = $(".current-date"),

$qiandaoBnt = $("#js-just-qiandao"),

_html = '',

_handle = true,

myDate = new Date()

$currentDate.text(myDate.getFullYear() + '年' + parseInt(myDate.getMonth() + 1) + '月' + myDate.getDate() + '日')       var monthFirst = new Date(myDate.getFullYear(), parseInt(myDate.getMonth()), 1).getDay()       var d = new Date(myDate.getFullYear(), parseInt(myDate.getMonth() + 1), 0)       var totalDay = d.getDate()//获取当前月的天数

for (var i = 0i <42i++) {

_html += ' <li><div class="qiandao-icon"></div></li>'

}

$dateBox.html(_html) //生成日历网格

var $dateLi = $dateBox.find("li")       for (var i = 0i <totalDayi++) {

$dateLi.eq(i + monthFirst).addClass("date" + parseInt(i + 1))           for (var j = 0j <dateArray.lengthj++) {                if (i == dateArray[j]) {

$dateLi.eq(i).addClass("qiandao")                   var integral                   if(talentIntegralRecordsIntegral[j]==0){

integral="大转盘"

}else{

integral="+"+talentIntegralRecordsIntegral[j]

}

$dateLi.eq(i).find("div").text(integral)

}

}

} //生成当月的日历且含已签到

$(".date" + myDate.getDate()).addClass('able-qiandao')

$dateBox.on("click", "li", function() {                if ($(this).hasClass('able-qiandao') &&_handle) {

$(this).addClass('qiandao')

qiandaoFun()

}