最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

JavaScript實現(xiàn)大樂透號碼生成的實例分析

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 20:11:34
文檔

JavaScript實現(xiàn)大樂透號碼生成的實例分析

JavaScript實現(xiàn)大樂透號碼生成的實例分析:這個大樂透號碼生成器純前端開發(fā),涉及HTML、JS、CSS。為了簡單起見,把所有代碼寫到了一個html文件中,這樣的好處就是可以直接用瀏覽器打開這個文件,當(dāng)然實際工作中最好把他們放在不同的文件。整個區(qū)域放在一個大的p標(biāo)簽中,表現(xiàn)為一個矩形區(qū)域,并通過
推薦度:
導(dǎo)讀JavaScript實現(xiàn)大樂透號碼生成的實例分析:這個大樂透號碼生成器純前端開發(fā),涉及HTML、JS、CSS。為了簡單起見,把所有代碼寫到了一個html文件中,這樣的好處就是可以直接用瀏覽器打開這個文件,當(dāng)然實際工作中最好把他們放在不同的文件。整個區(qū)域放在一個大的p標(biāo)簽中,表現(xiàn)為一個矩形區(qū)域,并通過
這個“大樂透號碼生成器”純前端開發(fā),涉及HTML、JS、CSS。為了簡單起見,把所有代碼寫到了一個html文件中,這樣的好處就是可以直接用瀏覽器打開這個文件,當(dāng)然實際工作中最好把他們放在不同的文件。整個區(qū)域放在一個大的p標(biāo)簽中,表現(xiàn)為一個矩形區(qū)域,并通過JS控制顯示的位置;設(shè)置一個下拉列表,可以選擇生成1-5組隨機號碼,當(dāng)點擊按鈕后,就能生成相應(yīng)組數(shù)的號碼;號碼區(qū)域分兩部分,上面部分是隨機生成的無序的號碼,下面部分是對這些無序號碼進行排序后的號碼,生成組數(shù)受上面下拉列表控制。這個工具的核心是生成隨機號碼和對隨機號碼進行排序,這兩步都是通過JS代碼實現(xiàn)的。下面介紹一些重要的JS代碼。

生成隨機號碼:大樂透分前區(qū)號碼和后區(qū)號碼,前區(qū)號碼是從01-35中無重復(fù)地取5個號碼,后區(qū)號碼是從01-12中無重復(fù)地取2個號碼,組成一組7位的號碼。這里定義了兩個數(shù)組:arr35存放前區(qū)的01-35號碼,arr12存放后區(qū)的01-12號碼。通過“temp = Math.floor(Math.random()*arr35.length)”方法從0-arr35.length取一個隨機數(shù)作為索引,通過arr35[temp]即可獲取數(shù)組中該索引位置的值,也就是隨機號碼,然后通過獲取id動態(tài)添加到排序前的span中。取完以后通過“arr35.splice(temp,1);”即可刪除數(shù)組中該隨機數(shù),同時使數(shù)組長度減一。循環(huán)5次即可從01-35中無重復(fù)地取5個隨機號碼,后面兩位同樣如此。

var arr35 = ["01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17", 
"18","19","20","21","22","23","24","25","26","27","28","29","30","31","32","33","34","35"];
var arr12 = ["01","02","03","04","05","06","07","08","09","10","11","12"];
var span = "";
var temp = "";
for(var i=1;i<6;i++){
 span = "span" + x + i;
 temp = Math.floor(Math.random()*arr35.length);//隨機取一個數(shù)
 document.getElementById(span).innerText = arr35[temp];
 document.getElementById(span).style.backgroundColor = "red";
 arr35.splice(temp,1);//刪除該位置的值}

隨機號碼排序:這里用到了插入排序算法,只是對每組號碼的前五位進行排序,數(shù)據(jù)量很小,排序完之后通過獲取id動態(tài)添加到排序后的span中。

//插入排序
function bubbleSort(array){ 
var len = array.length; 
for (var i = 0; i < len; i++) { 
for (var j = i; j > 0 && array[j]<array[j-1]; j--) { 
var swap = array[j]; //第二個for循環(huán)使元素比較并移動到合適位置
 array[j] = array[j-1];
 array[j-1] = swap;
 }
 } return array;
}

其余的JS以及HTML、CSS技術(shù)不再詳細(xì)介紹。

完整代碼:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>大樂透號碼生成器</title>
<style type="text/css">
#table{
width:800px; 
height:500px;
margin:10px;
border:2px 
solid 
#000000;
box-shadow: 10px 10px 5px;border-radius:50px;}
.buttonStyle{height:40px;margin:20px;font-size:20px;background-color:#6495ED;color:white;border-radius:10px;}
.oneStyle{margin-left:200px;margin-top:10px;font-family:sans-serif;font-size:20px;}
span{border-radius: 50%;color: #FFFFFF;padding:3px;font-size:13px;}
</style>
</head>
<body>
 <p id="table">
 <p>
 <h1 style="text-align:center">大樂透號碼生成器</h1>
 </p>
 <p class="oneStyle">
 生成組數(shù):<select id="zushu" style="width:150px;height:30px;margin:10px;" onchange="select()">
 <option value="1">生成 1 組號碼</option>
 <option value="2">生成 2 組號碼</option>
 <option value="3">生成 3 組號碼</option>
 <option value="4">生成 4 組號碼</option>
 <option value="5">生成 5 組號碼</option>
 </select>
 </p>
 <p class="oneStyle">
 隨機號碼1:<span id="span11"></span> <span id="span12"></span> <span id="span13"></span> 
 <span id="span14"></span> <span id="span15"></span>
    <span id="span16"></span> <span id="span17"></span><br>
 隨機號碼2:<span id="span21"></span> <span id="span22"></span> <span id="span23"></span> 
 <span id="span24"></span> <span id="span25"></span>
    <span id="span26"></span> <span id="span27"></span><br>
 隨機號碼3:<span id="span31"></span> <span id="span32"></span> <span id="span33"></span> 
 <span id="span34"></span> <span id="span35"></span>
    <span id="span36"></span> <span id="span37"></span><br>
 隨機號碼4:<span id="span41"></span> <span id="span42"></span> <span id="span43"></span> 
 <span id="span44"></span> <span id="span45"></span>
    <span id="span46"></span> <span id="span47"></span><br>
 隨機號碼5:<span id="span51"></span> <span id="span52"></span> <span id="span53"></span> 
 <span id="span54"></span> <span id="span55"></span>
    <span id="span56"></span> <span id="span57"></span><br>
 </p>
 <p class="oneStyle">
 排序后碼1:<span id="span61"></span> <span id="span62"></span> <span id="span63"></span> 
 <span id="span64"></span> <span id="span65"></span>
    <span id="span66"></span> <span id="span67"></span><br>
 排序后碼2:<span id="span71"></span> <span id="span72"></span> <span id="span73"></span> 
 <span id="span74"></span> <span id="span75"></span>
    <span id="span76"></span> <span id="span77"></span><br>
 排序后碼3:<span id="span81"></span> <span id="span82"></span> <span id="span83"></span> 
 <span id="span84"></span> <span id="span85"></span>
    <span id="span86"></span> <span id="span87"></span><br>
 排序后碼4:<span id="span91"></span> <span id="span92"></span> <span id="span93"></span> 
 <span id="span94"></span> <span id="span95"></span>
    <span id="span96"></span> <span id="span97"></span><br>
 排序后碼5:<span id="span101"></span> <span id="span102"></span> <span id="span103"></span> 
 <span id="span104"></span> <span id="span105"></span>
    <span id="span106"></span> <span id="span107"></span><br>
 </p>
 <p style="text-align:center">
 <input class="buttonStyle" id="fiveNumber" type="button" onclick="number()">
 </p>
 </p>
 <script type="text/javascript">
 var table = document.getElementById("table"); 
 var width = document.documentElement.clientWidth; //瀏覽器可見區(qū)域?qū)? var height = document.documentElement.clientHeight; //瀏覽器可見區(qū)域高 
 table.style.marginLeft = ((width-800)/2)+"px"; 
 table.style.marginTop = ((height-700)/2)+"px";
 var val = "1";
 document.getElementById("fiveNumber").setAttribute("title","生成 1 組號碼");
 document.getElementById("fiveNumber").setAttribute("value","生成 1 組號碼"); 
 //隨機生成五組號碼
 function select()
 {
 val = document.getElementById("zushu").value; 
 var des = "生成 " + val + " 組號碼";
 document.getElementById("fiveNumber").setAttribute("title",des);
 document.getElementById("fiveNumber").setAttribute("value",des);
 } //隨機生成五組號碼
 function number()
 { for(var n=1;n<11;n++){ 
 for(var m=1;m<8;m++){ 
 var a = "span" + n + m;
 document.getElementById(a).innerText = "";//每次點擊按鈕先清空上一次數(shù)據(jù) 
 document.getElementById(a).style.backgroundColor = "white";
 }
 } for(var x=1;x<(parseInt(val)+1);x++){ //從35個號碼里面無放回地取5位
 var arr35 = ["01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17", 
 "18","19","20","21","22","23","24","25","26","27","28","29","30","31","32","33","34","35"]; 
 //從12個號碼里面無放回地取2位
 var arr12 = ["01","02","03","04","05","06","07","08","09","10","11","12"]; 
 var span = ""; 
 var temp = ""; 
 for(var i=1;i<6;i++){
 span = "span" + x + i;
 temp = Math.floor(Math.random()*arr35.length);//隨機取一個數(shù) 
 document.getElementById(span).innerText = arr35[temp];
 document.getElementById(span).style.backgroundColor = "red";
 arr35.splice(temp,1);//刪除該位置的值 
 } 
 for(var j=6;j<8;j++){
 span = "span" + x + j;
 temp = Math.floor(Math.random()*arr12.length);//隨機取一個數(shù) 
 document.getElementById(span).innerText = arr12[temp];
 document.getElementById(span).style.backgroundColor = "blue";
 arr12.splice(temp,1);//刪除該位置的值 
 }
 } 
 for(var x=1;x<(parseInt(val)+1);x++){ 
 var span = ""; //前五位排序
 var arr = new Array(5); 
 for(var y=0;y<5;y++){
 span = "span" + x + (y+1);
 arr[y] = document.getElementById(span).lastChild.nodeValue;
 } var a = bubbleSort(arr); 
 for(var l=0;l<5;l++){
 span = "span" + (x+5) + (l+1);
 document.getElementById(span).innerText = a[l];
 document.getElementById(span).style.backgroundColor = "red";
 } //后兩位排序
 var spann6 = "span" + x + "6"; 
 var spann7 = "span" + x + "7"; 
 var spanm6 = "span" + (x+5) + "6"; 
 var spanm7 = "span" + (x+5) + "7"; 
 var span6 = document.getElementById(spann6).lastChild.nodeValue; 
 var span7 = document.getElementById(spann7).lastChild.nodeValue; 
 if(parseInt(span6) > parseInt(span7)){
 document.getElementById(spanm6).innerText = span7;
 document.getElementById(spanm7).innerText = span6;
 }else{
 document.getElementById(spanm6).innerText = span6;
 document.getElementById(spanm7).innerText = span7;
 }
 document.getElementById(spanm6).style.backgroundColor = "blue";
 document.getElementById(spanm7).style.backgroundColor = "blue";
 }
 } //插入排序
 function bubbleSort(array){ 
 var len = array.length; 
 for (var i = 0; i < len; i++) { 
 for (var j = i; j > 0 && array[j]<array[j-1]; j--) { 
 var swap = array[j]; //第二個for循環(huán)使元素比較并移動到合適位置 
 array[j] = array[j-1];
 
 array[j-1] = swap;
 }
 } return array;
 } </script></body></html>

瀏覽器打開效果:

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JavaScript實現(xiàn)大樂透號碼生成的實例分析

JavaScript實現(xiàn)大樂透號碼生成的實例分析:這個大樂透號碼生成器純前端開發(fā),涉及HTML、JS、CSS。為了簡單起見,把所有代碼寫到了一個html文件中,這樣的好處就是可以直接用瀏覽器打開這個文件,當(dāng)然實際工作中最好把他們放在不同的文件。整個區(qū)域放在一個大的p標(biāo)簽中,表現(xiàn)為一個矩形區(qū)域,并通過
推薦度:
標(biāo)簽: 生成 號碼 js
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top