>  기사  >  웹 프론트엔드  >  js에서 슬라이딩 도어 효과를 얻는 방법

js에서 슬라이딩 도어 효과를 얻는 방법

王林
王林앞으로
2020-03-10 10:35:131852검색

js에서 슬라이딩 도어 효과를 얻는 방법

1. 슬라이딩 도어 구현에 필요한 기술

1. 간단한 기본 HTML 지식

2. 간단한 기본 CSS 스타일

(추천 튜토리얼:

javascript 튜토리얼

)2. 구현방법

HTML

<div id="container">
  <img src="images/20190503222903.png"/><!--图片可以自己修改-->
  <img src="images/20190503222943.png"/>
  <img src="images/20190503223003.png"/>
  <img src="images/20190503223514.png"/>
</div>

CSS

*{
  margin: 0;
  padding: 0;
  background-color: #ccc;
}
p{
  text-align: center;
}
#container{
  width: 1130px;
  height: 350px;
  margin: 0 auto;
  border-right:1px solid #FF0000;
  border-bottom:1px solid #FF0000;
  overflow: hidden;
  position: relative;
}
#container img{
  width:500px;
  height:350px;
  display: block;
  position: absolute;
  border-bottm:1px solid #FF0000;
}

JS

//加载dom树
window.onload = function(){
//定义盒子
var box=document.getElementById(&#39;container&#39;);
//定义图片
var imgs=box.getElementsByTagName(&#39;img&#39;);
//图片宽度
var imgWidth = imgs[0].offsetWidth;
//隐藏宽度
var exposeWidth = 210;
//盒子宽度
var boxWidth = imgWidth + (imgs.length -1) * exposeWidth;
box.style.width=&#39;px&#39;;
//设置每道门的初始位置
function SetImgsPos(){
for(var i = 1;i<imgs.length;i++){
      imgs[i].style.left = imgWidth + exposeWidth*(i -1)+ &#39;px&#39;;
      }
    }
    SetImgsPos();
     //计算每道门应该移动的距离
    var translate = imgWidth - exposeWidth;
    //为每道门绑定事件
    for(var i=0;i<imgs.length;i++){
      //使用立即调用的函数表达式,为了获得不同的i值
      (function(i){
        imgs[i].onmouseover = function(){
          SetImgsPos();
          //打开门
          for(var j=1;j<=i;j++){
            imgs[j].style.left = parseInt(imgs[j].style.left,10) - translate + &#39;px&#39;;
          }
        }
      })(i);
    }
  }

더 많은 프로그래밍 관련 내용은 PHP 중국어 홈페이지

프로그래밍 입문

칼럼을 주목해주세요!

위 내용은 js에서 슬라이딩 도어 효과를 얻는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 jb51.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제