JSはアコーディオンの効果を実現します。
本論文の実例はJSのアコーディオン実現の具体的なコードを共有しています。
効果図
効果図
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title> </title>
<link rel="stylesheet" href="index.css" rel="external nofollow" >
</head>
<body>
<div class="wrapper">
<ul class="wrapUl">
<li>
<div class="title">
<h1> </h1>
</div>
<div class="picBox picBox1"></div>
<div class="decration"> ? , , 。 ?</div>
</li>
<li>
<div class="title">
<h1> </h1>
</div>
<div class="picBox picBox2"></div>
<div class="decration"> , , , , 、 ……</div>
</li>
<li>
<div class="title">
<h1> </h1>
</div>
<div class="picBox picBox3"></div>
<div class="decration"> , , </div>
</li>
<li>
<div class="title">
<h1> </h1>
</div>
<div class="picBox picBox4"></div>
<div class="decration"> , 。 , 。 </div>
</li>
<li>
<div class="title">
<h1> </h1>
</div>
<div class="picBox picBox5"></div>
<div class="decration"> , , ; , , </div>
</li>
<li>
<div class="title">
<h1> </h1>
</div>
<div class="picBox picBox6"></div>
<div class="decration"> , , , , , </div>
</li>
<li>
<div class="title">
<h1> </h1>
</div>
<div class="picBox picBox7"></div>
<div class="decration"> , , , </div>
</li>
</ul>
</div>
<script src="jquery.js"></script>
<script src="index.js"></script>
</body>
</html>
JSコード
var oUl = $('ul'),
oLi = $('li'),
len = oLi.length,
width = parseInt(oUl.css('width')),
gw = width / len,
ot = Math.floor((width - 400) / (len - 1));
flag = true;
function init(){
if(flag){
change($(oLi[len-1]));
}
}
function bindEvent(){
oLi.on('click',function(){
change($(this));
if(($(this).index() +1) == len){
flag = false;
}else{
flag = true;
}
});
oUl.on('mouseleave',function(){
init();
})
}
function change(event){
event.animate({
'width':'400px'
},300,'linear').siblings().animate({
'width':ot + 'px'
},300,'linear');
event.find('.title').css({
'display':'none'
})
event.siblings().find('.title').css({
'display':'block'
})
event.find('.decration').css({
'bottom':'0px'
})
event.siblings().find('.decration').css({
'bottom':'-50px'
})
}
init();
bindEvent();
CSSコード
*{
margin:0;
padding:0;
list-style:none;
}
body{
background-color:#333;
}
.wrapper{
width:80%;
margin:50px auto;
padding:40px;
}
.wrapper ul{
width:100%;
height:300px;
overflow: hidden;
}
.wrapper ul li{
float: left;
width:14.2;
height:260px;
position:relative;
overflow:hidden;
cursor:pointer;
}
.picBox{
width:100%;
height:100%;
}
.picBox1{
background:url(images/1.jpg) no-repeat center 0;
}
.picBox2{
background:url(images/2.jpg) no-repeat center 0;
}
.picBox3{
background:url(images/3.jpg) no-repeat center 0;
}
.picBox4{
background:url(images/4.jpg) no-repeat center 0;
}
.picBox5{
background:url(images/5.jpg) no-repeat center 0;
}
.picBox6{
background:url(images/6.jpg) no-repeat center 0;
}
.picBox7{
background:url(images/7.jpg) no-repeat center 0;
}
.wrapper ul li .title{
position:absolute;
overflow:hidden;
width:100%;
height:100%;
left:0;
top:0;
background:rgba(0,0,0,0.5);
}
.wrapper ul li .title h1{
color:#fff;
width:30px;
margin:0 auto;
display:block;
font:20px;
padding-top:30px;
opacity:0.8;
}
.wrapper ul li .decration{
width:400px;
height:40px;
padding-left:20px;
padding-right:30px;
position:absolute;
left:0;
bottom:-50px;
background:rgba(0,0,0,0.3);
color:#FFF;
}
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。