(html&css&js 3D载入动画,js控制样式、随机动态颜色)
若有疑问可评论留言或私信
index.html
<!DOCTYPE html>
<html lang="cn">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<link rel="stylesheet" href="css/index.css">
</head>
<body>
//载入动画部分
<div>
<div>
<ul>
<li>载</li>
<li>载</li>
<li>载</li>
<li>载</li>
</ul>
<ul>
<li>入</li>
<li>入</li>
<li>入</li>
<li>入</li>
</ul>
<ul>
<li>中</li>
<li>中</li>
<li>中</li>
<li>中</li>
</ul>
</div>
</div>
//载入动画部分end
//js改变样式部分
<input type="text">
//js改变样式部分end
</body>
<script src="js/index.js"></script>
</html>
index.css
*{
margin:0;
padding:0;
border:0;
}
body>div:first-of-type{
width:100%;
height:1000px;
padding-top:300px;
background:white;
position:fixed;
top:0px;
left:0px;
text-align:center;
}
body div:first-of-type>div{
width: 180px;
margin: 0 auto;
background: green;
}
ul{
position: relative;
width: 60px;
height: 60px;
float: left;
transform-style: preserve-3d;
animation: move 1.5s infinite linear;
}
@keyframes move{
0%{
transform: rotateX(0deg);
}
100%{
transform: rotateX(360deg);
}
}
ul:nth-of-type(2){
animation: moveT 1.5s infinite linear;
}
@keyframes moveT{
0%{
transform: rotateX(0deg);
}
100%{
transform: rotateX(-360deg);
}
}
li{
//css实现载入动画,后js控制动画结束
position: absolute;
width: 50px;
height: 50px;
line-height: 50px;
left: 0;
top: 0;
}
ul:first-of-type li{
border:5px dashed lime;
background: white;
}
ul:nth-of-type(2) li{
border:5px dashed red;
background: white;
}
ul:nth-of-type(3) li{
border:5px dashed aqua;
background: white;
}
ul li:nth-of-type(1){
transform: translateZ(30px);
}
ul li:nth-of-type(2){
transform: translateZ(-30px) rotateZ(180deg) rotateY(180deg);
}
ul li:nth-of-type(3){
transform: translateY(30px) rotateX(-90deg);
}
ul li:nth-of-type(4){
transform: translateY(-30px) rotateX(90deg);
}
index.js
//随机颜色函数,每次调用生成不同颜色,透明度
function randomColor(){
return ('rgba('+parseInt(Math.random()*256)
+','+parseInt(Math.random()*256)
+','+parseInt(Math.random()*256)
+',0.'+parseInt(Math.random()*11)+')');
}
//接收参数:html标签对象、边框样式
function labels(labelSelect,borderStyle){
labelSelect.style.cssText='font-size:20px;font-weight:bold;text-align:center;word-break:break-all;transition:0.3s;color:'+randomColor()+';background:'+randomColor()+';border:5px '+randomColor()+' '+borderStyle+';';
}
function inputStyle(){
var inputLabel=document.querySelector('input');
//引用labels函数,传入参数
labels(inputLabel,'solid');
}
//每300毫秒随机分配给input颜色样式
setInterval(inputStyle,300);
//载入页面1.5秒结束载入动画(隐藏包含动画的div标签)
setTimeout(function(){
document.querySelestor('div').style.cssText='display:none;';
},1500);
END