純CSS3實現(xiàn)的井字棋游戲
發(fā)布時間:2020-11-25 17:05:27 作者:Žiga Miklič
我要評論
這篇文章主要介紹了純CSS3實現(xiàn)的井字棋游戲,幫助大家更好的理解和使用CSS,感興趣的朋友可以了解下
運行效果:

html
<div class="tic-tac-toe">
<input class="player-1 left first-column top first-row first-diagonal turn-1" id="block1-1-1" type="radio"/>
<label class="turn-1" for="block1-1-1"></label>
<input class="player-1 middle second-column top first-row turn-1" id="block1-1-2" type="radio"/>
<label class="turn-1" for="block1-1-2"></label>
<input class="player-1 right third-column top first-row second-diagonal turn-1" id="block1-1-3" type="radio"/>
<label class="turn-1" for="block1-1-3"></label>
<input class="player-1 left first-column center second-row turn-1" id="block1-2-1" type="radio"/>
<label class="turn-1" for="block1-2-1"></label>
<input class="player-1 middle second-column center second-row first-diagonal second-diagonal turn-1" id="block1-2-2" type="radio"/>
<label class="turn-1" for="block1-2-2"></label>
<input class="player-1 right third-column center second-row turn-1" id="block1-2-3" type="radio"/>
<label class="turn-1" for="block1-2-3"></label>
<input class="player-1 left first-column bottom third-row second-diagonal turn-1" id="block1-3-1" type="radio"/>
<label class="turn-1" for="block1-3-1"></label>
<input class="player-1 middle second-column bottom third-row turn-1" id="block1-3-2" type="radio"/>
<label class="turn-1" for="block1-3-2"></label>
<input class="player-1 right third-column bottom third-row first-diagonal turn-1" id="block1-3-3" type="radio"/>
<label class="turn-1" for="block1-3-3"></label>
<input class="player-2 left first-column top first-row first-diagonal turn-2" id="block2-1-1" type="radio"/>
<label class="turn-2" for="block2-1-1"></label>
<input class="player-2 middle second-column top first-row turn-2" id="block2-1-2" type="radio"/>
<label class="turn-2" for="block2-1-2"></label>
<input class="player-2 right third-column top first-row second-diagonal turn-2" id="block2-1-3" type="radio"/>
<label class="turn-2" for="block2-1-3"></label>
<input class="player-2 left first-column center second-row turn-2" id="block2-2-1" type="radio"/>
<label class="turn-2" for="block2-2-1"></label>
<input class="player-2 middle second-column center second-row first-diagonal second-diagonal turn-2" id="block2-2-2" type="radio"/>
<label class="turn-2" for="block2-2-2"></label>
<input class="player-2 right third-column center second-row turn-2" id="block2-2-3" type="radio"/>
<label class="turn-2" for="block2-2-3"></label>
<input class="player-2 left first-column bottom third-row second-diagonal turn-2" id="block2-3-1" type="radio"/>
<label class="turn-2" for="block2-3-1"></label>
<input class="player-2 middle second-column bottom third-row turn-2" id="block2-3-2" type="radio"/>
<label class="turn-2" for="block2-3-2"></label>
<input class="player-2 right third-column bottom third-row first-diagonal turn-2" id="block2-3-3" type="radio"/>
<label class="turn-2" for="block2-3-3"></label>
<input class="player-1 left first-column top first-row first-diagonal turn-3" id="block3-1-1" type="radio"/>
<label class="turn-3" for="block3-1-1"></label>
<input class="player-1 middle second-column top first-row turn-3" id="block3-1-2" type="radio"/>
<label class="turn-3" for="block3-1-2"></label>
<input class="player-1 right third-column top first-row second-diagonal turn-3" id="block3-1-3" type="radio"/>
<label class="turn-3" for="block3-1-3"></label>
<input class="player-1 left first-column center second-row turn-3" id="block3-2-1" type="radio"/>
<label class="turn-3" for="block3-2-1"></label>
<input class="player-1 middle second-column center second-row first-diagonal second-diagonal turn-3" id="block3-2-2" type="radio"/>
<label class="turn-3" for="block3-2-2"></label>
<input class="player-1 right third-column center second-row turn-3" id="block3-2-3" type="radio"/>
<label class="turn-3" for="block3-2-3"></label>
<input class="player-1 left first-column bottom third-row second-diagonal turn-3" id="block3-3-1" type="radio"/>
<label class="turn-3" for="block3-3-1"></label>
<input class="player-1 middle second-column bottom third-row turn-3" id="block3-3-2" type="radio"/>
<label class="turn-3" for="block3-3-2"></label>
<input class="player-1 right third-column bottom third-row first-diagonal turn-3" id="block3-3-3" type="radio"/>
<label class="turn-3" for="block3-3-3"></label>
<input class="player-2 left first-column top first-row first-diagonal turn-4" id="block4-1-1" type="radio"/>
<label class="turn-4" for="block4-1-1"></label>
<input class="player-2 middle second-column top first-row turn-4" id="block4-1-2" type="radio"/>
<label class="turn-4" for="block4-1-2"></label>
<input class="player-2 right third-column top first-row second-diagonal turn-4" id="block4-1-3" type="radio"/>
<label class="turn-4" for="block4-1-3"></label>
<input class="player-2 left first-column center second-row turn-4" id="block4-2-1" type="radio"/>
<label class="turn-4" for="block4-2-1"></label>
<input class="player-2 middle second-column center second-row first-diagonal second-diagonal turn-4" id="block4-2-2" type="radio"/>
<label class="turn-4" for="block4-2-2"></label>
<input class="player-2 right third-column center second-row turn-4" id="block4-2-3" type="radio"/>
<label class="turn-4" for="block4-2-3"></label>
<input class="player-2 left first-column bottom third-row second-diagonal turn-4" id="block4-3-1" type="radio"/>
<label class="turn-4" for="block4-3-1"></label>
<input class="player-2 middle second-column bottom third-row turn-4" id="block4-3-2" type="radio"/>
<label class="turn-4" for="block4-3-2"></label>
<input class="player-2 right third-column bottom third-row first-diagonal turn-4" id="block4-3-3" type="radio"/>
<label class="turn-4" for="block4-3-3"></label>
<input class="player-1 left first-column top first-row first-diagonal turn-5" id="block5-1-1" type="radio"/>
<label class="turn-5" for="block5-1-1"></label>
<input class="player-1 middle second-column top first-row turn-5" id="block5-1-2" type="radio"/>
<label class="turn-5" for="block5-1-2"></label>
<input class="player-1 right third-column top first-row second-diagonal turn-5" id="block5-1-3" type="radio"/>
<label class="turn-5" for="block5-1-3"></label>
<input class="player-1 left first-column center second-row turn-5" id="block5-2-1" type="radio"/>
<label class="turn-5" for="block5-2-1"></label>
<input class="player-1 middle second-column center second-row first-diagonal second-diagonal turn-5" id="block5-2-2" type="radio"/>
<label class="turn-5" for="block5-2-2"></label>
<input class="player-1 right third-column center second-row turn-5" id="block5-2-3" type="radio"/>
<label class="turn-5" for="block5-2-3"></label>
<input class="player-1 left first-column bottom third-row second-diagonal turn-5" id="block5-3-1" type="radio"/>
<label class="turn-5" for="block5-3-1"></label>
<input class="player-1 middle second-column bottom third-row turn-5" id="block5-3-2" type="radio"/>
<label class="turn-5" for="block5-3-2"></label>
<input class="player-1 right third-column bottom third-row first-diagonal turn-5" id="block5-3-3" type="radio"/>
<label class="turn-5" for="block5-3-3"></label>
<input class="player-2 left first-column top first-row first-diagonal turn-6" id="block6-1-1" type="radio"/>
<label class="turn-6" for="block6-1-1"></label>
<input class="player-2 middle second-column top first-row turn-6" id="block6-1-2" type="radio"/>
<label class="turn-6" for="block6-1-2"></label>
<input class="player-2 right third-column top first-row second-diagonal turn-6" id="block6-1-3" type="radio"/>
<label class="turn-6" for="block6-1-3"></label>
<input class="player-2 left first-column center second-row turn-6" id="block6-2-1" type="radio"/>
<label class="turn-6" for="block6-2-1"></label>
<input class="player-2 middle second-column center second-row first-diagonal second-diagonal turn-6" id="block6-2-2" type="radio"/>
<label class="turn-6" for="block6-2-2"></label>
<input class="player-2 right third-column center second-row turn-6" id="block6-2-3" type="radio"/>
<label class="turn-6" for="block6-2-3"></label>
<input class="player-2 left first-column bottom third-row second-diagonal turn-6" id="block6-3-1" type="radio"/>
<label class="turn-6" for="block6-3-1"></label>
<input class="player-2 middle second-column bottom third-row turn-6" id="block6-3-2" type="radio"/>
<label class="turn-6" for="block6-3-2"></label>
<input class="player-2 right third-column bottom third-row first-diagonal turn-6" id="block6-3-3" type="radio"/>
<label class="turn-6" for="block6-3-3"></label>
<input class="player-1 left first-column top first-row first-diagonal turn-7" id="block7-1-1" type="radio"/>
<label class="turn-7" for="block7-1-1"></label>
<input class="player-1 middle second-column top first-row turn-7" id="block7-1-2" type="radio"/>
<label class="turn-7" for="block7-1-2"></label>
<input class="player-1 right third-column top first-row second-diagonal turn-7" id="block7-1-3" type="radio"/>
<label class="turn-7" for="block7-1-3"></label>
<input class="player-1 left first-column center second-row turn-7" id="block7-2-1" type="radio"/>
<label class="turn-7" for="block7-2-1"></label>
<input class="player-1 middle second-column center second-row first-diagonal second-diagonal turn-7" id="block7-2-2" type="radio"/>
<label class="turn-7" for="block7-2-2"></label>
<input class="player-1 right third-column center second-row turn-7" id="block7-2-3" type="radio"/>
<label class="turn-7" for="block7-2-3"></label>
<input class="player-1 left first-column bottom third-row second-diagonal turn-7" id="block7-3-1" type="radio"/>
<label class="turn-7" for="block7-3-1"></label>
<input class="player-1 middle second-column bottom third-row turn-7" id="block7-3-2" type="radio"/>
<label class="turn-7" for="block7-3-2"></label>
<input class="player-1 right third-column bottom third-row first-diagonal turn-7" id="block7-3-3" type="radio"/>
<label class="turn-7" for="block7-3-3"></label>
<input class="player-2 left first-column top first-row first-diagonal turn-8" id="block8-1-1" type="radio"/>
<label class="turn-8" for="block8-1-1"></label>
<input class="player-2 middle second-column top first-row turn-8" id="block8-1-2" type="radio"/>
<label class="turn-8" for="block8-1-2"></label>
<input class="player-2 right third-column top first-row second-diagonal turn-8" id="block8-1-3" type="radio"/>
<label class="turn-8" for="block8-1-3"></label>
<input class="player-2 left first-column center second-row turn-8" id="block8-2-1" type="radio"/>
<label class="turn-8" for="block8-2-1"></label>
<input class="player-2 middle second-column center second-row first-diagonal second-diagonal turn-8" id="block8-2-2" type="radio"/>
<label class="turn-8" for="block8-2-2"></label>
<input class="player-2 right third-column center second-row turn-8" id="block8-2-3" type="radio"/>
<label class="turn-8" for="block8-2-3"></label>
<input class="player-2 left first-column bottom third-row second-diagonal turn-8" id="block8-3-1" type="radio"/>
<label class="turn-8" for="block8-3-1"></label>
<input class="player-2 middle second-column bottom third-row turn-8" id="block8-3-2" type="radio"/>
<label class="turn-8" for="block8-3-2"></label>
<input class="player-2 right third-column bottom third-row first-diagonal turn-8" id="block8-3-3" type="radio"/>
<label class="turn-8" for="block8-3-3"></label>
<input class="player-1 left first-column top first-row first-diagonal turn-9" id="block9-1-1" type="radio"/>
<label class="turn-9" for="block9-1-1"></label>
<input class="player-1 middle second-column top first-row turn-9" id="block9-1-2" type="radio"/>
<label class="turn-9" for="block9-1-2"></label>
<input class="player-1 right third-column top first-row second-diagonal turn-9" id="block9-1-3" type="radio"/>
<label class="turn-9" for="block9-1-3"></label>
<input class="player-1 left first-column center second-row turn-9" id="block9-2-1" type="radio"/>
<label class="turn-9" for="block9-2-1"></label>
<input class="player-1 middle second-column center second-row first-diagonal second-diagonal turn-9" id="block9-2-2" type="radio"/>
<label class="turn-9" for="block9-2-2"></label>
<input class="player-1 right third-column center second-row turn-9" id="block9-2-3" type="radio"/>
<label class="turn-9" for="block9-2-3"></label>
<input class="player-1 left first-column bottom third-row second-diagonal turn-9" id="block9-3-1" type="radio"/>
<label class="turn-9" for="block9-3-1"></label>
<input class="player-1 middle second-column bottom third-row turn-9" id="block9-3-2" type="radio"/>
<label class="turn-9" for="block9-3-2"></label>
<input class="player-1 right third-column bottom third-row first-diagonal turn-9" id="block9-3-3" type="radio"/>
<label class="turn-9" for="block9-3-3"></label>
<div class="end">
<h3></h3><a href="">Restart</a>
</div>
</div>
<h5>Note: use the Full Page view for the best experience.</h5>
css3
@charset "UTF-8";
/* Variables
-------------------------------------------------------------- */
/* Body and Notice styling
-------------------------------------------------------------- */
body {
color: #b6b5ca;
font-family: 'Arial', sans-serif;
margin: 0;
text-align: center;
}
h5 {
font-weight: 400;
padding: 0 20px;
}
/* Tic-tac-toe game
-------------------------------------------------------------- */
.tic-tac-toe {
font-family: 'Open Sans', sans-serif;
height: 300px;
overflow: hidden;
margin: 50px auto 30px auto;
position: relative;
width: 300px;
}
@media (min-width: 450px) {
.tic-tac-toe {
height: 450px;
width: 450px;
}
}
.tic-tac-toe input[type="radio"] {
display: none;
}
.tic-tac-toe input[type="radio"]:checked + label {
cursor: default;
z-index: 10 !important;
}
.tic-tac-toe input[type="radio"].player-1 + label:after {
content: "";
}
.tic-tac-toe input[type="radio"].player-2 + label:after {
content: "";
}
.tic-tac-toe input[type="radio"].player-1:checked + label:after, .tic-tac-toe input[type="radio"].player-2:checked + label:after {
opacity: 1;
}
.tic-tac-toe input[type="radio"].player-1:checked + label {
background-color: #dc685a;
}
.tic-tac-toe input[type="radio"].player-2:checked + label {
background-color: #ecaf4f;
}
.tic-tac-toe input[type="radio"].turn-1 + label {
z-index: 1;
}
.tic-tac-toe input[type="radio"].turn-2 + label {
z-index: 2;
}
.tic-tac-toe input[type="radio"].turn-3 + label {
z-index: 3;
}
.tic-tac-toe input[type="radio"].turn-4 + label {
z-index: 4;
}
.tic-tac-toe input[type="radio"].turn-5 + label {
z-index: 5;
}
.tic-tac-toe input[type="radio"].turn-6 + label {
z-index: 6;
}
.tic-tac-toe input[type="radio"].turn-7 + label {
z-index: 7;
}
.tic-tac-toe input[type="radio"].turn-8 + label {
z-index: 8;
}
.tic-tac-toe input[type="radio"].turn-9 + label {
z-index: 9;
}
.tic-tac-toe input[type="radio"].turn-1 + label {
display: block;
}
.tic-tac-toe input[type="radio"].turn-1:checked ~ .turn-2 + label {
display: block;
}
.tic-tac-toe input[type="radio"].turn-2:checked ~ .turn-3 + label {
display: block;
}
.tic-tac-toe input[type="radio"].turn-3:checked ~ .turn-4 + label {
display: block;
}
.tic-tac-toe input[type="radio"].turn-4:checked ~ .turn-5 + label {
display: block;
}
.tic-tac-toe input[type="radio"].turn-5:checked ~ .turn-6 + label {
display: block;
}
.tic-tac-toe input[type="radio"].turn-6:checked ~ .turn-7 + label {
display: block;
}
.tic-tac-toe input[type="radio"].turn-7:checked ~ .turn-8 + label {
display: block;
}
.tic-tac-toe input[type="radio"].turn-8:checked ~ .turn-9 + label {
display: block;
}
.tic-tac-toe input[type="radio"].left + label {
left: 0;
}
.tic-tac-toe input[type="radio"].top + label {
top: 0;
}
.tic-tac-toe input[type="radio"].middle + label {
left: 100px;
}
.tic-tac-toe input[type="radio"].right + label {
left: 200px;
}
.tic-tac-toe input[type="radio"].center + label {
top: 100px;
}
.tic-tac-toe input[type="radio"].bottom + label {
top: 200px;
}
@media (min-width: 450px) {
.tic-tac-toe input[type="radio"].middle + label {
left: 150px;
}
.tic-tac-toe input[type="radio"].right + label {
left: 300px;
}
.tic-tac-toe input[type="radio"].center + label {
top: 150px;
}
.tic-tac-toe input[type="radio"].bottom + label {
top: 300px;
}
}
.tic-tac-toe input[type="radio"]:checked ~ input[type="radio"]:checked ~ input[type="radio"]:checked ~
input[type="radio"]:checked ~ input[type="radio"]:checked ~ input[type="radio"]:checked ~
input[type="radio"]:checked ~ input[type="radio"]:checked ~ input[type="radio"]:checked ~ .end {
display: block;
}
.tic-tac-toe input[type="radio"]:checked ~ input[type="radio"]:checked ~ input[type="radio"]:checked ~
input[type="radio"]:checked ~ input[type="radio"]:checked ~ input[type="radio"]:checked ~
input[type="radio"]:checked ~ input[type="radio"]:checked ~ input[type="radio"]:checked ~ .end > h3:before {
content: "It is a tie!";
}
.tic-tac-toe .player-1.first-column:checked ~ .player-1.first-column:checked ~ .player-1.first-column:checked ~ .end,
.tic-tac-toe .player-1.second-column:checked ~ .player-1.second-column:checked ~ .player-1.second-column:checked ~ .end,
.tic-tac-toe .player-1.third-column:checked ~ .player-1.third-column:checked ~ .player-1.third-column:checked ~ .end,
.tic-tac-toe .player-1.first-row:checked ~ .player-1.first-row:checked ~ .player-1.first-row:checked ~ .end,
.tic-tac-toe .player-1.second-row:checked ~ .player-1.second-row:checked ~ .player-1.second-row:checked ~ .end,
.tic-tac-toe .player-1.third-row:checked ~ .player-1.third-row:checked ~ .player-1.third-row:checked ~ .end,
.tic-tac-toe .player-1.first-diagonal:checked ~ .player-1.first-diagonal:checked ~ .player-1.first-diagonal:checked ~ .end,
.tic-tac-toe .player-1.second-diagonal:checked ~ .player-1.second-diagonal:checked ~ .player-1.second-diagonal:checked ~ .end {
display: block;
}
.tic-tac-toe .player-1.first-column:checked ~ .player-1.first-column:checked ~ .player-1.first-column:checked ~ .end h3:before,
.tic-tac-toe .player-1.second-column:checked ~ .player-1.second-column:checked ~ .player-1.second-column:checked ~ .end h3:before,
.tic-tac-toe .player-1.third-column:checked ~ .player-1.third-column:checked ~ .player-1.third-column:checked ~ .end h3:before,
.tic-tac-toe .player-1.first-row:checked ~ .player-1.first-row:checked ~ .player-1.first-row:checked ~ .end h3:before,
.tic-tac-toe .player-1.second-row:checked ~ .player-1.second-row:checked ~ .player-1.second-row:checked ~ .end h3:before,
.tic-tac-toe .player-1.third-row:checked ~ .player-1.third-row:checked ~ .player-1.third-row:checked ~ .end h3:before,
.tic-tac-toe .player-1.first-diagonal:checked ~ .player-1.first-diagonal:checked ~ .player-1.first-diagonal:checked ~ .end h3:before,
.tic-tac-toe .player-1.second-diagonal:checked ~ .player-1.second-diagonal:checked ~ .player-1.second-diagonal:checked ~ .end h3:before {
content: "Player 1 wins!" !important;
}
.tic-tac-toe .player-2.first-column:checked ~ .player-2.first-column:checked ~ .player-2.first-column:checked ~ .end,
.tic-tac-toe .player-2.second-column:checked ~ .player-2.second-column:checked ~ .player-2.second-column:checked ~ .end,
.tic-tac-toe .player-2.third-column:checked ~ .player-2.third-column:checked ~ .player-2.third-column:checked ~ .end,
.tic-tac-toe .player-2.first-row:checked ~ .player-2.first-row:checked ~ .player-2.first-row:checked ~ .end,
.tic-tac-toe .player-2.second-row:checked ~ .player-2.second-row:checked ~ .player-2.second-row:checked ~ .end,
.tic-tac-toe .player-2.third-row:checked ~ .player-2.third-row:checked ~ .player-2.third-row:checked ~ .end,
.tic-tac-toe .player-2.first-diagonal:checked ~ .player-2.first-diagonal:checked ~ .player-2.first-diagonal:checked ~ .end,
.tic-tac-toe .player-2.second-diagonal:checked ~ .player-2.second-diagonal:checked ~ .player-2.second-diagonal:checked ~ .end {
display: block;
}
.tic-tac-toe .player-2.first-column:checked ~ .player-2.first-column:checked ~ .player-2.first-column:checked ~ .end h3:before,
.tic-tac-toe .player-2.second-column:checked ~ .player-2.second-column:checked ~ .player-2.second-column:checked ~ .end h3:before,
.tic-tac-toe .player-2.third-column:checked ~ .player-2.third-column:checked ~ .player-2.third-column:checked ~ .end h3:before,
.tic-tac-toe .player-2.first-row:checked ~ .player-2.first-row:checked ~ .player-2.first-row:checked ~ .end h3:before,
.tic-tac-toe .player-2.second-row:checked ~ .player-2.second-row:checked ~ .player-2.second-row:checked ~ .end h3:before,
.tic-tac-toe .player-2.third-row:checked ~ .player-2.third-row:checked ~ .player-2.third-row:checked ~ .end h3:before,
.tic-tac-toe .player-2.first-diagonal:checked ~ .player-2.first-diagonal:checked ~ .player-2.first-diagonal:checked ~ .end h3:before,
.tic-tac-toe .player-2.second-diagonal:checked ~ .player-2.second-diagonal:checked ~ .player-2.second-diagonal:checked ~ .end h3:before {
content: "Player 2 wins!" !important;
}
.tic-tac-toe label {
background-color: #78bec5;
border-radius: 14px;
cursor: pointer;
color: #fff;
display: none;
height: 90px;
margin: 5px;
position: absolute;
width: 90px;
-moz-transition: background-color 0.3s;
-o-transition: background-color 0.3s;
-webkit-transition: background-color 0.3s;
transition: background-color 0.3s;
}
@media (min-width: 450px) {
.tic-tac-toe label {
height: 140px;
width: 140px;
}
}
.tic-tac-toe label:hover {
background-color: #3d4250;
}
.tic-tac-toe label:hover:after {
opacity: .4;
}
.tic-tac-toe label:after {
left: 0;
font-family: "FontAwesome";
font-size: 45px;
margin-top: -22.5px;
opacity: 0;
position: absolute;
text-align: center;
text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);
top: 50%;
width: 100%;
}
@media (min-width: 450px) {
.tic-tac-toe label:after {
font-size: 70px;
margin-top: -35px;
}
}
.tic-tac-toe .end {
background: rgba(255, 255, 255, 0.8);
bottom: 5px;
color: #3d4250;
display: none;
left: 5px;
padding-top: 55px;
position: absolute;
right: 5px;
top: 5px;
text-align: center;
z-index: 11;
}
@media (min-width: 450px) {
.tic-tac-toe .end {
padding-top: 110px;
}
}
.tic-tac-toe .end h3 {
font-size: 30px;
font-weight: 300;
}
@media (min-width: 450px) {
.tic-tac-toe .end h3 {
font-size: 40px;
}
}
.tic-tac-toe .end a {
background-color: #3d4250;
border-radius: 4px;
color: #fff;
padding: 14px 45px;
text-decoration: none;
-moz-transition: background-color 0.2s;
-o-transition: background-color 0.2s;
-webkit-transition: background-color 0.2s;
transition: background-color 0.2s;
}
.tic-tac-toe .end a:hover {
background-color: #262934;
cursor: pointer;
以上就是純CSS3實現(xiàn)的井字棋游戲的詳細內(nèi)容,更多關(guān)于CSS3 井字棋游戲的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章

CSS3 最強二維布局系統(tǒng)之Grid 網(wǎng)格布局
CS3的Grid網(wǎng)格布局是目前最強的二維布局系統(tǒng),可以同時對列和行進行處理,將網(wǎng)頁劃分成一個個網(wǎng)格,可以任意組合不同的網(wǎng)格,做出各種各樣的布局,本文介紹CSS3 最強二維布局系2025-02-27- 本文介紹了如何使用CSS3的transform屬性和動畫技巧實現(xiàn)波浪式圖片墻,通過設(shè)置圖片的垂直偏移量,并使用動畫使其周期性地改變位置,可以創(chuàng)建出動態(tài)且具有波浪效果的圖片墻,同2025-02-27

CSS3模擬實現(xiàn)一個雷達探測掃描動畫特效(最新推薦)
文章介紹了如何使用CSS3實現(xiàn)一個雷達探測掃描的效果,包括夜色背景、蜘蛛網(wǎng)盤、掃描體的轉(zhuǎn)動效果、尾巴陰影以及被掃描到的光點,通過HTML和CSS的配合,實現(xiàn)了豐富的動畫效果,2025-02-21- CSS3的Flexbox是一種強大的布局模式,通過設(shè)置display:flex可以輕松實現(xiàn)對齊、排列和分布網(wǎng)頁元素,它解決了傳統(tǒng)布局方法中的對齊、間距分配和自適應(yīng)布局等問題,接下來通過本2025-02-19

css3 實現(xiàn)icon刷新轉(zhuǎn)動效果
本文給大家介紹css3 實現(xiàn)icon刷新轉(zhuǎn)動效果,文章開頭給大家介紹了webkit-transform、animation、@keyframes這三個屬性,結(jié)合實例代碼給大家介紹的非常詳細,感興趣的朋友一2025-02-19- CSS3過渡屬性用于實現(xiàn)元素從一種樣式平滑過渡到另一種樣式,通過設(shè)置transition-property過渡屬性、transition-duration過渡時長transition-timing-function過渡函數(shù)和trans2025-02-19
CSS3實現(xiàn)動態(tài)旋轉(zhuǎn)加載樣式的示例代碼
本文介紹了如何使用CSS3創(chuàng)建一個簡單的動態(tài)旋轉(zhuǎn)加載樣式,通過定義一個帶有類名“l(fā)oader”的HTML元素,并使用CSS樣式和@keyframes規(guī)則來實現(xiàn)旋轉(zhuǎn)動畫,你可以根據(jù)需要調(diào)整樣式2025-02-19- 這篇文章主要介紹了如何使用CSS3的transition屬性實現(xiàn)平滑的過渡動畫,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧2025-02-13

CSS3中使用flex和grid實現(xiàn)等高元素布局的示例代碼
本文介紹了使用CSS3中的Flexbox和Grid布局實現(xiàn)等高元素布局的方法,通過簡單的兩列實現(xiàn)、每行放置3列以及全部代碼的展示,展示了這兩種布局方式的實現(xiàn)細節(jié)和效果,感興趣的朋2025-02-11- CSS3和SVG的結(jié)合使用為網(wǎng)頁設(shè)計帶來了創(chuàng)新的動態(tài)視覺效果,本文通過一個圓形進度條的動畫特效示例,展示了如何利用CSS3的動畫功能和SVG的矢量圖形能力來創(chuàng)建豐富的用戶交互體2024-10-24





