溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

js怎么實(shí)現(xiàn)隨機(jī)數(shù)小游戲

發(fā)布時(shí)間:2021-04-19 12:39:01 來源:億速云 閱讀:286 作者:小新 欄目:web開發(fā)

小編給大家分享一下js怎么實(shí)現(xiàn)隨機(jī)數(shù)小游戲,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

具體內(nèi)容如下

1、HTML結(jié)構(gòu)代碼如下

<div class="mask">
 <div class="contents">
  <div class="head">
   <p>誰去拿外賣</p>
   <a href="#" id="close">X</a>
  </div>
  <div class="cont-wapper">
   <div class="cont-inner">
    <h3></h3>
    <button></button>
    <div class="sign">隨機(jī)到最小數(shù)字的人去拿外賣</div>
    <ul>
     <li class="takeout-list">扔出了一個(gè)2</li>
     <li>扔出了一個(gè)3</li>
    </ul>
   </div>
  </div>
 </div>
</div>

2、css樣式代碼如下

.mask { 
 position: fixed;left: 0;top: 0;
 width: 100%;height: 100%;
 background: rgba(0, 0, 0, 0.5);
}

.contents {
 position: absolute;top: 54px;left: 50%;
 width: 360px;border: 1px solid gray;background: white;
 border-radius: 5px;transform: translateX(-50%); 
}
.head {
 box-sizing: border-box;width: 100%;height: 44px;
 padding: 10px;border-bottom: 1px solid #eee; 
}
.head p {
 float: left;
}
.head a {
 float: right;width: 16px;
 line-height: 24px;color: #ccc;
}
.head a:hover {
 color: blue;
}
.cont-wapper {
 width: 300px;color: #555;
 padding: 15px 30px;margin: 0 auto;
}
 .cont-inner {
 font-size: 12px;background: #dbf0fa;
 padding-top: 15px;margin: 0 auto;
 margin-bottom: 10px;box-shadow: 1px 1px 2px #ddd;
}
 .cont-inner h3 {
 width: 186px;height: 188px;margin: 0 auto;
 background: url('../../Content/img1/ico.png') 0 -120px no-repeat;
}
.cont-inner button {
 display: block;cursor: pointer;/*箭頭變手*/
 outline:none;/*去掉瀏覽器默認(rèn)的外邊框*/
 width: 271px;height: 40px;border: 0;
 background: url('../../Content/img1/ico.png') 0 0 no-repeat;
 margin: -45px auto 15px;
}
 .sign {
 position: relative;text-align: center;
 color: #777;margin-bottom: 10px;
}
/*after偽元素在元素之后添加內(nèi)容*/
/*content 屬性與 :before 及 :after 偽元素配合使用,來插入生成內(nèi)容*/
.sign::after {   
 content: '';display: block;
 position: absolute;width: 40px;height: 7px;
 background: #ccc;right: 16px;top: 5px;
}
/*before偽元素在元素之前添加內(nèi)容。*/
/*content 屬性與 :before 及 :after 偽元素配合使用,來插入生成內(nèi)容*/
 .sign::before {
 content: '';display: block;position: absolute;
 width: 40px;height: 7px;
 background: #ccc;left: 16px;top: 5px;
}
 .cont-inner ul {
 height: 180px;margin: 0 10px;
 padding: 5px 5px 0 5px;
 overflow: hidden;/*隱藏滾動(dòng)條*/
}
.cont-wapper li.takeout-list {
 color: #fe5a23;font-weight: 600;
 height: 19px;line-height: 19px;
 background: url('../../Content/img1/ico.png') 0 -320px no-repeat;
}
.cont-wapper li {
 padding-left: 5px;
}

3、js代碼獲取元素

var button = document.getElementsByTagName('button')[0];//按鈕
var ullist = document.getElementsByTagName('ul')[0];
var arrList = [];//創(chuàng)建數(shù)組
var mask = document.getElementsByClassName('mask')[0];
var text = document.getElementsByClassName('contents')[0];
var min = NaN;//最小值
var index;//索引值

4、js代碼實(shí)現(xiàn)鼠標(biāo)滑過的時(shí)候背景的動(dòng)態(tài)變化

//鼠標(biāo)按下事件
button.onmousedown = function () {
 this.style.backgroundPosition = '0 ' + (-80) + 'px';
 cteatNumer()//調(diào)用生成數(shù)組的方法
 //鼠標(biāo)放開事件
 this.onmouseup = function () {
  this.style.backgroundPosition = '0 ' + (-40) + 'px';
 }
};
//鼠標(biāo)移入事件
button.onmouseenter = function () {
 this.style.backgroundPosition = '0 ' + (-40) + 'px';
 //鼠標(biāo)移出事件
 this.onmouseleave = function () {
  this.style.backgroundPosition = '0 ' + 0 + 'px';
 }
};

5、js代碼實(shí)現(xiàn)在數(shù)組輸出最小值

//在數(shù)組中輸出最小值
Array.prototype.min = function () {
 var min = this[0];//目前生成的數(shù)值
 var len = this.length;//數(shù)組目前的長度
 for (var i = 1; i < len; i++) {
  if (this[i] < min) {
   min = this[i];
  }
 }
 return min;
}

6、js代碼實(shí)現(xiàn)取出數(shù)組的最小值

//數(shù)組取最小值
function cteatNumer() {
 var num = Math.floor(Math.random() * 100);//0-100之間隨機(jī)生成一個(gè)精準(zhǔn)的實(shí)數(shù)
 if (min == num) {//判斷是否有最小值重復(fù) 
  cteatNumer();//有重復(fù)就重新生成
  return;
 }  
 arrList.push(num);//在數(shù)組最下面顯示生成的值
 if (arrList.length > 11) {//數(shù)組長度超出11
  if (num > min && index == 0) {//當(dāng)最小值索引值為0時(shí)
   arrList.splice(1, 1);//從數(shù)組索引值為1開始,刪除第2個(gè)數(shù)值
  } else {
   arrList.shift();//數(shù)組往上移動(dòng)
  }
 }
 min = arrList.min();//最小值
 index = arrList.indexOf(min);//最小值在數(shù)組中的索引
 refurbishDom(arrList, index);//調(diào)用refurbishDom方法
}

7、用for循環(huán)遍歷當(dāng)前數(shù)組的長度

function refurbishDom(arr, index) {
 ullist.innerHTML = '';//清空ul所有的數(shù)值
 var len = arr.length;//獲取當(dāng)前數(shù)組的長度
 for (var i = 0; i < len; i++) {//顯示對(duì)應(yīng)索引的數(shù)值
  ullist.innerHTML += '<li>' + '扔出了一個(gè)' + arr[i] + '</li>';
 }
 //在ul數(shù)組中動(dòng)態(tài)指定最小值
 ullist.getElementsByTagName('li')[index].className = 'takeout-list';
}

以上是“js怎么實(shí)現(xiàn)隨機(jī)數(shù)小游戲”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI