JS+CSS繪制棋盤格的示例代碼
在這篇文章中,我將展示如何使用 css 和一些 JavaScript 來設(shè)計棋盤。
為此,你需要對 CSS Flex-box 和 nth-child() 屬性有基本的了解。
所以讓我們開始吧......
實現(xiàn)思路
我們將為每個偶數(shù)行添加 containerEven 類作為父容器,為每個奇數(shù)行添加 containerOdd,
下面顯示了相同的 CSS
.containerEven>div:nth-child(odd) { background-color: white; } .containerEven>div:nth-child(even) { background-color: black; } .containerOdd>div:nth-child(odd) { background-color: black; } .containerOdd>div:nth-child(even) { background-color: white; }
這是html部分
<div class="parent-class"> <section class="containerEven" id='container1'></section> <section class="containerOdd" id='container2'></section> <section class="containerEven" id='container3'></section> <section class="containerOdd" id='container4'></section> <section class="containerEven" id='container5'></section> <section class="containerOdd" id='container6'></section> <section class="containerEven" id='container7'></section> <section class="containerOdd" id='container8'></section> </div>
現(xiàn)在剩下的就是使用 javascript 在相應(yīng)的 id 的幫助下在這些部分標簽內(nèi)動態(tài)附加元素。
var res1 = [], res2 = [], res3 = [], res4 = [], res5 = [], res6 = [], res7 = [], res8 = []; for (i = 1; i <= 8; i++) { res1 += `<div class="item"></div>` res2 += `<div class="item"></div>` res3 += `<div class="item"></div>` res4 += `<div class="item"></div>` res5 += `<div class="item"></div>` res6 += `<div class="item"></div>` res7 += `<div class="item"></div>` res8 += `<div class="item"></div>` } document.getElementById(`container1`).innerHTML = res1; document.getElementById(`container2`).innerHTML = res2; document.getElementById(`container3`).innerHTML = res3; document.getElementById(`container4`).innerHTML = res4; document.getElementById(`container5`).innerHTML = res5; document.getElementById(`container6`).innerHTML = res6; document.getElementById(`container7`).innerHTML = res7; document.getElementById(`container8`).innerHTML = res8;
在這里我們所做的是使用 8 個數(shù)組來存儲每一行??數(shù)據(jù)。當我們得到數(shù)據(jù)再將其附加到相應(yīng)的容器 id,
完整代碼
下面是帶有輸出的完整代碼
<style> .parent-class { border: 5px chocolate groove; } .containerEven, .containerOdd { display: flex; background-color: dodgerblue; } .item { background-color: #f1f1f1; padding: 20px; font-size: 30px; flex: 1; height: 50px; text-align: center; } .containerEven>div:nth-child(odd) { background-color: white; } .containerEven>div:nth-child(even) { background-color: black; } .containerOdd>div:nth-child(odd) { background-color: black; } .containerOdd>div:nth-child(even) { background-color: white; } </style> <div class="parent-class"> <section class="containerEven" id='container1'></section> <section class="containerOdd" id='container2'></section> <section class="containerEven" id='container3'></section> <section class="containerOdd" id='container4'></section> <section class="containerEven" id='container5'></section> <section class="containerOdd" id='container6'></section> <section class="containerEven" id='container7'></section> <section class="containerOdd" id='container8'></section> </div> <script> var res1 = [], res2 = [], res3 = [], res4 = [], res5 = [], res6 = [], res7 = [], res8 = []; for (i = 1; i <= 8; i++) { res1 += `<div class="item"></div>` res2 += `<div class="item"></div>` res3 += `<div class="item"></div>` res4 += `<div class="item"></div>` res5 += `<div class="item"></div>` res6 += `<div class="item"></div>` res7 += `<div class="item"></div>` res8 += `<div class="item"></div>` } document.getElementById(`container1`).innerHTML = res1; document.getElementById(`container2`).innerHTML = res2; document.getElementById(`container3`).innerHTML = res3; document.getElementById(`container4`).innerHTML = res4; document.getElementById(`container5`).innerHTML = res5; document.getElementById(`container6`).innerHTML = res6; document.getElementById(`container7`).innerHTML = res7; document.getElementById(`container8`).innerHTML = res8; </script>
效果展示
到此這篇關(guān)于JS+CSS繪制棋盤格的示例代碼的文章就介紹到這了,更多相關(guān)JS棋盤格內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
bootstrap 日期控件 datepicker被彈出框dialog覆蓋的解決辦法
這篇文章主要介紹了bootstrap 日期控件 datepicker被彈出框dialog覆蓋的解決辦法 ,本文給大家分享幾種解決方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07BootStrap table刪除指定行的注意事項(筆記整理)
在前端開發(fā)中遇到這樣的問題,對于table指定行的數(shù)據(jù)進行刪除,花了好長時間才解決,今天小編抽時間給大家介紹BootStrap table刪除指定行的注意事項,需要的朋友參考下吧2017-02-02談?wù)凧avaScript類型系統(tǒng)之Math
Math 對象并不像 Date 和 String 那樣是對象的類,因此沒有構(gòu)造函數(shù) Math(),像 Math.sin() 這樣的函數(shù)只是函數(shù),不是某個對象的方法。您無需創(chuàng)建它,通過把 Math 作為對象使用就可以調(diào)用其所有屬性和方法2016-01-01