亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Javascript構建Bingo卡片游戲

2019-11-10 19:05:32
字體:
來源:轉載
供稿:網友

預備知識點: 1、 “< table >”表示表格, “< tr >”表示表格的開始一行, “< th>”表示表格中列的標題單元格, “< td>”表示表格中的每個單元格 2、常用的字符含義 ”&nbsp“表示空格 & & < < > > " ” &qpos; ‘

一、靜態bingo區

程序代碼區: Html片段:

<!DOCTYPE html><html><head><title>Make Your Own Bingo Card</title><link rel="stylesheet" href="script01.CSS"><script src="script01.js"></script></head><body><h1>Create A Bingo Card</h1><table><tr><th>B</th><th>I</th><th>N</th><th>G</th><th>O</th></tr><tr><td id="square0">&nbsp;</td> <!--&nbsp表示空格--><td id="square5">&nbsp;</td><td id="square10">&nbsp;</td><td id="square14">&nbsp;</td><td id="square19">&nbsp;</td></tr><tr><td id="square1">&nbsp;</td><td id="square6">&nbsp;</td><td id="square11">&nbsp;</td><td id="square15">&nbsp;</td><td id="square20">&nbsp;</td></tr><tr><td id="square2">&nbsp;</td><td id="square7">&nbsp;</td><td id="free">Free</td><td id="square16">&nbsp;</td><td id="square21">&nbsp;</td></tr><tr><td id="square3">&nbsp;</td><td id="square8">&nbsp;</td><td id="square12">&nbsp;</td><td id="square17">&nbsp;</td><td id="square22">&nbsp;</td></tr><tr><td id="square4">&nbsp;</td><td id="square9">&nbsp;</td><td id="square13">&nbsp;</td><td id="square18">&nbsp;</td><td id="square23">&nbsp;</td></tr></table><p><a href="script01.html" id="reload">Click here</a> to create a new card</p></body></html>

css片段:

body {background-color: white;color: black;font-size: 20px;font-family: "Lucida Grande", Verdana,Arial, Helvetica, sans-serif;}h1, th {font-family: Georgia, "Times New Roman",Times, serif;}h1 {font-size: 28px;}table {border-collapse: collapse;}th, td {padding: 10px;border: 2px #666 solid;text-align: center;width: 20%;}#free, .pickedBG {background-color: #f66;<!--控制Free的鍵-->}.winningBG {background-image:url(images/redFlash.gif);}

js的片段

window.onload = initAll;//窗口的顯示加載,調用initAll()函數,事件處理程序調用函數function initAll() {for (var i=0; i<24; i++) {var newNum = Math.floor(Math.random() * 75) + 1;//javaScript 命令Math.random()生成0~1 的一個隨機數;floor運算會獲得結果的整數部,最后獲得1到最大值+1的結果document.getElementById("square" + i).innerHTML = newNum;}}

靜態的展示結果 這里寫圖片描述

修改js的代碼:使用值傳遞的方式:

window.onload = initAll;function initAll() {for (var i=0; i<24; i++) {setSquare(i);}}function setSquare(thisSquare) {var currSquare = "square" + thisSquare;var newNum = Math.floor(Math.random() * 75) + 1;document.getElementById(currSquare). innerHTML = newNum;}

探測對象:對象探測拒絕這種老式瀏覽器(Mac 的Netscape 4)并顯示這個錯誤消息。

window.onload = initAll;function initAll() {if (document.getElementById) {for (var i=0; i<24; i++) {setSquare(i);}}else {alert("Sorry, your browser doesn't support this script");}}function setSquare(thisSquare) {var currSquare = "square" + thisSquare;var newNum = Math.floor (Math.random() * 75) + 1;document.getElementById(currSquare).innerHTML = newNum;}

**消除重復的數字:更新數組 將數組的內容改為存儲當前值是一種非常強大的技術**

window.onload = initAll;var usedNums = new Array(76);function initAll() {if (document.getElementById) {for (var i=0; i<24; i++) {setSquare(i);}}else {alert("Sorry, your browser doesn't support this script");}}function setSquare(thisSquare) {var currSquare = "square" + thisSquare;var colPlace = new Array(0,0,0,0,0,1,1,1,1,1,2,2,2,2,3,3,3,3,3,4,4,4,4,4);var colBasis = colPlace [thisSquare] * 15;var newNum = colBasis + getNewNum() + 1;if (!usedNums[newNum]) {usedNums[newNum] = true;document.getElementById(currSquare).innerHTML = newNum;}}function getNewNum() {return Math.floor(Math.random() * 15);}

還允許用戶單擊頁面底部的鏈接來重新運行腳本,這樣就可以完全在 瀏覽器中生成Bingo 卡片,而不需要從服務器重新加載頁面。這向用戶提供了快速的響應,而且不會產生服務器負載。 讓用戶有能力自己運行腳本:

window.onload = initAll;var usedNums = new Array(76);function initAll() {if (document.getElementById) {document.getElementById("reload").onclick = anotherCard;newCard();}else {alert("Sorry, your browser doesn't support this script");}}function newCard() {for (var i=0; i<24; i++) {setSquare(i);}}function setSquare(thisSquare) {var currSquare = "square" + thisSquare;var colPlace = new Array(0,0,0,0,0,1,1,1,1,1,2,2,2,2,3,3,3,3,3,4,4,4,4,4);var colBasis = colPlace thisSquare] * 15;var newNum;do {newNum = colBasis + getNewNum() + 1;}while (usedNums[newNum]);usedNums[newNum] = true;document.getElementById(currSquare).innerHTML = newNum;}function getNewNum() {return Math.floor(Math.random() * 15);}function anotherCard() {for (var i=1; i<usedNums.length; i++) {usedNums[i]=false;}newCard();return false;}

通過Javascript 添加一個類,使代碼可以利用CSS 的功能

window.onload = initAll;var usedNums = new Array(76);function initAll() {if (document.getElementById) {document.getElementById("reload").onclick = anotherCard;newCard();}else {alert("Sorry, your browser doesn't support this script");}}function newCard() {for (var i=0; i<24; i++) {setSquare(i);}}function setSquare(thisSquare) {var currSquare = "square" + thisSquare;var colPlace = new Array(0,0,0,0,0,1,1,1,1,1,2,2,2,2,3,3,3,3,3,4,4,4,4,4);var colBasis = colPlace [thisSquare] * 15;var newNum;do {newNum = colBasis + getNewNum() + 1;}while (usedNums[newNum]);usedNums[newNum] = true;document.getElementById(currSquare).innerHTML = newNum;document.getElementById(currSquare).className = "";document.getElementById(currSquare).onmousedown = toggleColor;}function getNewNum() {return Math.floor(Math.random() * 15);}function anotherCard() {for (var i=1; i<usedNums.length; i++) {usedNums[i] = false;}newCard();return false;}function toggleColor(evt) {if (evt) {var thisSquare = evt.target;}else {var thisSquare = window.event.srcElement;}if (thisSquare.className == "") {thisSquare.className = "pickedBG";}else {thisSquare.className = "";}}

這個腳本使用復雜的數學計算判斷獲勝組合

window.onload = initAll;var usedNums = new Array(76);function initAll() {if (document.getElementById) {document.getElementById("reload").onclick = anotherCard;newCard();}else {alert("Sorry, your browser doesn't support this script");}}function newCard() {for (var i=0; i<24; i++) {setSquare(i);}}function setSquare(thisSquare) {var currSquare = "square" + thisSquare;var colPlace = new Array(0,0,0,0,0,1,1,1,1,1,2,2,2,2,3,3,3,3,3,4,4,4,4,4);var colBasis = colPlace [thisSquare] * 15;var newNum;do {newNum = colBasis + getNewNum() + 1;}while (usedNums[newNum]);usedNums[newNum] = true;document.getElementById(currSquare).innerHTML = newNum;document.getElementById(currSquare).className = "";document.getElementById(currSquare).onmousedown = toggleColor;}function getNewNum() {return Math.floor(Math.random() * 15);}function anotherCard() {for (var i=1; i<usedNums.length; i++) { usedNums[i] = false;1}newCard();return false;}function toggleColor(evt) {if (evt) {var thisSquare = evt.target;}else {var thisSquare = window.event.srcElement;}if (thisSquare.className == "") {thisSquare.className = "pickedBG";}else {thisSquare.className = "";}checkWin();}function checkWin() {var winningOption = -1;var setSquares = 0;var winners = new Array(31,992,15360,507904,541729,557328,1083458,2162820,4329736,8519745,8659472,16252928);for (var i=0; i<24; i++) {var currSquare = "square" + i;if (document.getElementById (currSquare).className != "") {document.getElementById (currSquare).className = "pickedBG";setSquares = setSquares | Math.pow(2,i);}}for (var i=0; i<winners.length; i++) {if ((winners[i] & setSquares) == winners[i]) {winningOption = i;}}if (winningOption > -1) {for (var i=0; i<24; i++) {if (winners[winningOption] & Math.pow(2,i)) {currSquare = "square" + i;document.getElementById (currSquare).className = "winningBG";}}}}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品免费观看在线| 91精品国产高清自在线| 欧美精品福利在线| 日韩国产在线播放| 日韩高清电影免费观看完整版| 国产欧美日韩免费| 国产精国产精品| 中文字幕日韩精品在线| 久久久精品久久久久| 久久久精品视频成人| 欧美激情在线观看视频| 国产福利精品av综合导导航| 97视频在线免费观看| 亚洲欧洲第一视频| 国产亚洲欧洲在线| 57pao国产成人免费| 国产一区二区三区在线观看视频| 亚洲成人激情图| 精品国产一区二区三区久久久| 日本成人黄色片| 久久久久久久久久久国产| 中文字幕日韩av| 欧美精品videos| 久久精品99国产精品酒店日本| 欧美精品生活片| 国产精品h在线观看| 成人午夜在线影院| 亚洲精品日韩欧美| 2019中文字幕在线| 色妞色视频一区二区三区四区| 日韩欧美高清视频| 精品久久香蕉国产线看观看亚洲| 91高潮在线观看| 在线午夜精品自拍| 色av中文字幕一区| 国内精品久久久| 日韩高清免费在线| 成人在线观看视频网站| 国产精品久久精品| 精品国内自产拍在线观看| 久久久久久国产精品美女| 成人精品久久一区二区三区| 国产亚洲激情在线| 国产精品久久久久久久app| 久久99热这里只有精品国产| 国产精品高清在线观看| 97在线日本国产| 亚洲欧美第一页| 国产精品毛片a∨一区二区三区|国| 欧美精品在线观看| 国产精品jizz在线观看麻豆| 欧美日韩国产在线| 中文字幕日韩视频| 日韩激情av在线播放| 亚洲福利在线视频| 92国产精品视频| 精品国内自产拍在线观看| 亚洲欧洲成视频免费观看| 欧美黑人极品猛少妇色xxxxx| 日韩视频精品在线| 亚洲视频在线观看免费| 国产亚洲aⅴaaaaaa毛片| 亚洲精品国产精品国自产观看浪潮| 国产成人精品在线观看| 国产精品美女www爽爽爽视频| 精品国产一区二区三区久久久狼| 欧美性高潮在线| 欧美精品18videosex性欧美| 国产精品久久久久久久久粉嫩av| 国产精品男女猛烈高潮激情| 精品国产福利视频| 免费av一区二区| 欧美又大粗又爽又黄大片视频| 国内精品久久久久久| 成人激情av在线| 亚洲理论电影网| 在线观看亚洲视频| 色婷婷综合久久久久中文字幕1| 蜜臀久久99精品久久久久久宅男| 欧美香蕉大胸在线视频观看| 欧美日韩免费看| 日韩一区二区三区xxxx| 国内免费久久久久久久久久久| 庆余年2免费日韩剧观看大牛| 欧美日本中文字幕| 久久这里只有精品视频首页| 亚洲精品国产综合区久久久久久久| 中文字幕在线观看亚洲| 高清欧美一区二区三区| 欧美午夜丰满在线18影院| 成人淫片在线看| 欧美日韩第一视频| 亚洲欧美国产一本综合首页| 国产精品久久久久久久久久久新郎| 日韩av电影手机在线观看| 亚洲一区二区少妇| 日本高清+成人网在线观看| www.日韩系列| 日韩中文字幕久久| 亚洲高清不卡av| 国产免费久久av| 欧美日韩在线视频一区二区| 日韩国产高清视频在线| 欧洲精品毛片网站| 欧美大胆a视频| 亚洲欧美精品一区二区| 日韩精品亚洲精品| 国产主播欧美精品| 日韩小视频在线观看| 成人有码视频在线播放| 精品久久久久久国产| 91av在线免费观看| 日韩免费av一区二区| www.日韩.com| 国产97在线观看| 日本精品一区二区三区在线| 欧美高清性猛交| 黄色一区二区三区| 2019中文在线观看| 国产日韩欧美中文| 国产精品美女www| 欧美午夜无遮挡| 欧美裸身视频免费观看| 日韩欧美国产高清91| 国产精品第一视频| 欧美日韩中文字幕在线视频| 日韩av在线电影网| 成人福利免费观看| www.亚洲一区| 日韩欧美成人区| 国产精品第3页| 中文字幕国产精品| 亚洲欧洲美洲在线综合| 久久久精品中文字幕| 成人免费观看49www在线观看| 国产精品xxx视频| 亚洲激情免费观看| 亚洲va久久久噜噜噜| 欧美老女人性生活| 欧美另类暴力丝袜| 久久久91精品国产一区不卡| 欧美精品日韩www.p站| 欧美精品videos另类日本| 亚洲成**性毛茸茸| 日韩欧美视频一区二区三区| 孩xxxx性bbbb欧美| 国产免费一区二区三区香蕉精| 国产91露脸中文字幕在线| 亚洲精品suv精品一区二区| 韩国美女主播一区| 国产精品www网站| 亚洲最大的成人网| 国产精品视频免费观看www| 在线电影欧美日韩一区二区私密| 国产精品影院在线观看| 精品美女久久久久久免费| 国产精品国产三级国产aⅴ浪潮| 爱福利视频一区| 欧美高清视频一区二区| 超碰91人人草人人干| 日韩亚洲欧美成人| 欧美裸体男粗大视频在线观看| 久久精品在线视频| 91视频九色网站|