欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實現(xiàn)簡單九宮格抽獎

 更新時間:2022年06月28日 15:42:26   作者:ResidualBridge  
這篇文章主要為大家詳細介紹了JS實現(xiàn)簡單九宮格抽獎,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

用JavaScript寫一個九宮格的抽獎盤,供大家參考,具體內(nèi)容如下

點擊中間的塊,選中獎品的亮塊會在邊緣的8個塊循環(huán);

選中后,彈出選中的內(nèi)容;

代碼參考:

HTML文件:

<body>
<div class="box">
? ? <ul id="jiangPin">
? ? ? ? <li><a href="javascript:viod(0);" ><span>獎品 1</span></a></li>
? ? ? ? <li><a href="javascript:viod(0);" ><span>獎品 2</span></a></li>
? ? ? ? <li><a href="javascript:viod(0);" ><span>獎品 3</span></a></li>
? ? ? ? <li><a href="javascript:viod(0);" ><span>獎品 4</span></a></li>
? ? ? ? <li><a href="javascript:viod(0);" ><span>獎品 5</span></a></li>
? ? ? ? <li><a href="javascript:viod(0);" ><span>獎品 6</span></a></li>
? ? ? ? <li><a href="javascript:viod(0);" ><span>獎品 7</span></a></li>
? ? ? ? <li><a href="javascript:viod(0);" ><span>獎品 8</span></a></li>
? ? </ul>
? ? <button type="button" class="btn" id="beginBtn">點擊開始</button>
? ? <div class="tishi" id="tishi">
? ? ? ? <span>恭喜您獲得:</span>
? ? ? ? <p></p>
? ? ? ? <button>確定</button>
? ? </div>
</div>
</body>

通過position定位來固定獎盤各個板塊的位置,將有獎品的8個塊分散在九宮格的邊緣,開始按鈕在九宮格正中間,將彈出的提示框放于整個獎盤的上層顯示,初始將其隱藏。

CSS文件:

.box{
? ? width: 450px;
? ? height: 450px;
? ? background-color: #9a6e3a;
? ? border: 2px solid #990055;
? ? position: relative;
? ? z-index: 10;
}
.box>ul>li{
? ? position: absolute;
? ? width: 148px;
? ? height: 148px;
? ? border: 1px #222222 solid;
? ? background-color: #ad889d;
}
.box>ul>li>a{
? ? display: block;
? ? color: #fff;
? ? font-size: 30px;
? ? text-align: center;
? ? line-height: 148px;
}
/* 開始按鈕 */
.btn{
? ? position: absolute;
? ? top: 150px;
? ? left: 150px;
? ? width: 150px;
? ? height: 150px;
? ? border: 1px #222222 solid;
? ? background-color: #7d53c7;
? ? outline: none;
? ? cursor: pointer;
? ? color: #fff;
? ? font-size: 25px;
? ? transition: all 0.5s;
? ? z-index: 20;
}
.btn:hover{
? ? background-color: #df04ff;
? ? font-size: 30px;
}
.btn:active{
? ? background-color: #7d53c7;
}
.box>ul>li.on{
? ? background-color: #f00;
}
/* 開始按鈕 end */

/* 獎品定位 */
.box>ul>li:nth-child(1){
? ? top: 0;
? ? left: 0;
}
.box>ul>li:nth-child(2){
? ? top: 0;
? ? left: 150px;
}
.box>ul>li:nth-child(3){
? ? top: 0;
? ? left: 300px;
}
.box>ul>li:nth-child(4){
? ? top: 150px;
? ? left: 300px;
}
.box>ul>li:nth-child(5){
? ? top: 300px;
? ? left: 300px;
}
.box>ul>li:nth-child(6){
? ? top: 300px;
? ? left: 150px;
}
.box>ul>li:nth-child(7){
? ? top: 300px;
? ? left: 0;
}
.box>ul>li:nth-child(8){
? ? top: 150px;
? ? left: 0;
}
/* 獎品定位 end */

/* 提示框 */
.tishi{
? ? width: 300px;
? ? height: 146px;
? ? border: 2px #990055 solid;
? ? background: #92EC1F;
? ? border-radius: 20px;
? ? position: absolute;
? ? left: 50%;
? ? top: 50%;
? ? margin-top: -75px;
? ? margin-left: -150px;
? ? z-index: 30;
? ? text-align: center;
? ? font-size: 25px;
? ? font-weight: bold;
? ? display: none;
? ? animation: tishiAni 0.5s both;
? ? transition: all 0.5s;
}
.tishi>p{
? ? color: red;
? ? font-size: 28px;
? ? margin-top: 20px;
}
.tishi>button{
? ? width: 60px;
? ? height: 30px;
? ? border:none;
? ? outline: none;
? ? cursor: pointer;
? ? position: absolute;
? ? right: 30px;
? ? bottom: 20px;
}
@keyframes tishiAni {
? ? 0%{
? ? ? ? opacity: 0;
? ? }
? ? 100%{
? ? ? ? opacity: 1;
? ? }
}
/* 提示框 end */

通過計時器來實現(xiàn)獎品亮塊的循環(huán)

JavaScript文件:

{
? ? let jiangPinChi = [
? ? ? ? "獎品1",
? ? ? ? "獎品2",
? ? ? ? "獎品3",
? ? ? ? "獎品4",
? ? ? ? "獎品5",
? ? ? ? "獎品6",
? ? ? ? "獎品7",
? ? ? ? "獎品8",
? ? ];

? ? let index = 0;
? ? let times = Math.round( Math.random()*20 ) +20 ;
? ? let jiangPin = document.getElementById("jiangPin");
? ? let beginBtn = document.getElementById("beginBtn");
? ? let tishi = document.getElementById("tishi");
? ? let cont = tishi.children;
? ? let jPLi = jiangPin.children;

? ? let liBro = function (tag) {
? ? ? ? let fat = tag.parentNode;
? ? ? ? let tagLi = fat.children;
? ? ? ? let othLis = [];
? ? ? ? for (let jPLi of tagLi) {
? ? ? ? ? ? if (jPLi === tag) {
? ? ? ? ? ? ? ? continue;
? ? ? ? ? ? }
? ? ? ? ? ? othLis.push(jPLi);
? ? ? ? }
? ? ? ? return othLis;
? ? };

? ? let showing = function( index ) {
? ? ? ? let othLis = liBro( jPLi[index] );
? ? ? ? for( let i = 0; i<=othLis.length-1 ; i++ ){
? ? ? ? ? ? othLis[i].classList.remove("on");
? ? ? ? }
? ? ? ? // othLis.forEach(function( value,i ){
? ? ? ? // ? ? value.classList.remove("on");
? ? ? ? // });
? ? ? ? jPLi[index].classList.add("on");
? ? };

? ? let changeFun = function( event ){
? ? ? ? let myset = setInterval(function(){
? ? ? ? ? ? index++;
? ? ? ? ? ? times--;
? ? ? ? ? ? if( index > jPLi.length-1 ){
? ? ? ? ? ? ? ? index = 0;
? ? ? ? ? ? }
? ? ? ? ? ? showing( index );
? ? ? ? ? ? if( times <= 0 ){
? ? ? ? ? ? ? ? clearInterval(myset);
? ? ? ? ? ? ? ? times = Math.round( Math.random()*20 ) +20;
? ? ? ? ? ? ? ? tishi.style.display = "block";
? ? ? ? ? ? ? ? cont[1].innerHTML = jiangPinChi[index];
? ? ? ? ? ? }
? ? ? ? },100);
? ? };
? ? beginBtn.addEventListener("click",changeFun);
? ? cont[2].addEventListener("click",function( event ){
? ? ? ? tishi.style.display = "none";
? ? });
}

當(dāng)然,這個可以擴展成更多的類型,實現(xiàn)不止九宮格的獎盤抽獎模式。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論