当前位置: 移动技术网 > IT编程>开发语言>JavaScript > js实现图片推拉门效果代码实例

js实现图片推拉门效果代码实例

2019年07月20日  | 移动技术网IT编程  | 我要评论
初学者。 推拉门是网页中常见的一种形式,通过js实现比较简单。主要是通过getelement找到节点元素,然后对其进行相应的赋值即可。 新建一个文件

初学者。

推拉门是网页中常见的一种形式,通过js实现比较简单。主要是通过getelement找到节点元素,然后对其进行相应的赋值即可。

新建一个文件,并在同一个目录中添加三个文件夹,images(用来当作“门”的图片),styles(用来存放css文件),scripts(用来存放js文件)。然后在中添加代码:

<!doctype html>
<html>
	<head>
	<meta charset="utf-8"/>
	<title>sliding doors</title>
	<link rel="stylesheet" href="styles/doors.css" rel="external nofollow" />
	<script src="scripts/doors.js"></script>
	</head>
	<body>
		<div id="container">
			<img src="images/door1.jpg" alt="柯南" title="柯南"/>
			<img src="images/door2.jpg" alt="柯南" title="柯南"/>
			<img src="images/door3.jpg" alt="柯南" title="柯南"/>
			<img src="images/door4.jpg" alt="柯南" title="柯南"/>
		</div>
	</body>
</html>

接着是styles目录下的doors.css:

#container{
	height:600px;
	border-right:1px solid #ccc;
	border-bottom:1px solid #ccc;
	margin:0 auto;
	position:relative;
	overflow:hidden;
}
 
#container img{
	position:absolute;
	border-left:1px solid #ccc;
	display:block;
	left:0;
}

然后是scripts目录下的doors.js:

window.onload = function()
{
	var box = document.getelementbyid("container"); //获得容器对象
	var imgs = box.getelementsbytagname("img"); //获得图片对象数组
	imgwidth = imgs[0].offsetwidth; //图片宽度
	var exposewidth = 100; //每张图片露出的宽度
	var boxwidth = imgwidth + exposewidth * (imgs.length - 1);
	box.style.width = boxwidth + "px";
	
	//初始化图片位置
	function reset()
	{
		for(var i = 1; i < imgs.length; i ++)
		{
			imgs[i].style.left = imgwidth + (i - 1) * exposewidth + "px";
		}
	} 
	reset();
	
	//开门时候每个图片应该左移的距离
	var translate = imgwidth - exposewidth;
	//为每个图片添加事件
	for(var i = 0; i < imgs.length; i ++)
	{
		
		//自动执行函数
		(function(i){
			imgs[i].onmouseover = function()
			{
				//重置图片位置
				reset();
				for(var j = 1; j <= i; j ++)
				{
					imgs[j].style.left = parseint(imgs[j].style.left, 10) - translate + "px";
					
				}
			};
			
		})(i);
	}
};

这样即可实现推拉门效果。

效果如下,截图略微粗糙

以上所述是小编给大家介绍的js实现图片推拉门效果代码实例详解整合,希望对大家有所帮助

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网