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


Posted in Javascript onMay 18, 2019

初学者。

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

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

<!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实现图片推拉门效果代码实例

以上所述是小编给大家介绍的js实现图片推拉门效果代码实例详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JS实现标签页效果(配合css)
Apr 03 Javascript
Javascript表单验证要注意的事项
Sep 29 Javascript
JavaScript中的变量作用域介绍
Dec 31 Javascript
Backbone.js的Hello World程序实例
Jun 19 Javascript
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
Dec 14 Javascript
解决webpack -p压缩打包react报语法错误的方法
Jul 03 Javascript
vue中使用gojs/jointjs的示例代码
Aug 24 Javascript
移动端如何用下拉刷新的方式实现上拉加载
Dec 10 Javascript
JavaScript的Proxy可以做哪些有意思的事儿
Jun 15 Javascript
jqGrid表格底部汇总、合计行footerrow处理
Aug 21 Javascript
一文看懂如何简单实现节流函数和防抖函数
Sep 05 Javascript
JavaScript实现淘宝商品图切换效果
Apr 29 Javascript
微信小程序代码上传、审核发布小程序
May 18 #Javascript
详解js中let与var声明变量的区别
Apr 05 #Javascript
webpack中如何加载静态文件的方法步骤
May 18 #Javascript
微信小程序实现录音时的麦克风动画效果实例
May 18 #Javascript
vue+egg+jwt实现登录验证的示例代码
May 18 #Javascript
egg.js的基本使用和调用数据库的方法示例
May 18 #Javascript
inquirer.js一个用户与命令行交互的工具详解
May 18 #Javascript
You might like
基于qmail的完整WEBMAIL解决方案安装详解
2006/10/09 PHP
PHP程序员最常犯的11个MySQL错误小结
2010/11/20 PHP
phpMyAdmin通过密码漏洞留后门文件
2018/11/20 PHP
thinkPHP5.1框架使用SemanticUI实现分页功能示例
2019/08/03 PHP
javascript 点击整页变灰的效果(可做退出效果)。
2008/01/09 Javascript
jquery 入门教程 [翻译] 推荐
2009/08/17 Javascript
IE和Firefox下event事件杂谈
2009/12/18 Javascript
javascript题目,重写函数让其无限相加
2012/02/15 Javascript
Javascript 页面模板化很多人没有使用过的方法
2012/06/05 Javascript
自定义jQuery选项卡插件实例
2013/03/27 Javascript
JS动态添加与删除select中的Option对象(示例代码)
2013/12/25 Javascript
iframe中使用jquery进行查找的方法【案例分析】
2016/06/17 Javascript
AngularJS入门教程之更多模板详解
2016/08/19 Javascript
jQuery插件FusionCharts实现的2D饼状图效果【附demo源码下载】
2017/03/03 Javascript
Bootstrap显示与隐藏简单实现代码
2017/03/06 Javascript
angularjs中ng-bind-html的用法总结
2017/05/23 Javascript
JS 判断某变量是否为某数组中的一个值的3种方法(总结)
2017/07/10 Javascript
详解如何用模块化的方式写vuejs
2017/12/16 Javascript
区别JavaScript函数声明与变量声明
2018/09/12 Javascript
史上最为详细的javascript继承(推荐)
2019/05/18 Javascript
wepy--用vantUI 实现上弹列表并选择相应的值操作
2020/11/03 Javascript
[45:16]完美世界DOTA2联赛PWL S3 Magma vs Phoenix 第一场 12.12
2020/12/16 DOTA
Python按行读取文件的简单实现方法
2016/06/22 Python
Python开发的实用计算器完整实例
2017/05/10 Python
在Python程序员面试中被问的最多的10道题
2017/12/05 Python
Python实现将json文件中向量写入Excel的方法
2018/03/26 Python
对Python w和w+权限的区别详解
2019/01/23 Python
Python 限定函数参数的类型及默认值方式
2019/12/24 Python
基于CSS3实现图片模糊过滤效果
2015/11/19 HTML / CSS
Darphin迪梵官网: 来自巴黎,植物和精油调制的护肤品牌
2016/10/11 全球购物
Clarria化妆品官方网站:购买天然和有机化妆品系列
2018/04/08 全球购物
Vero Moda西班牙官方购物网站:丹麦BESTSELLER旗下知名女装品牌
2018/04/27 全球购物
求职自我推荐信
2015/03/24 职场文书
2016年社区六一儿童节活动总结
2016/04/06 职场文书
详解MySQL的半同步
2021/04/22 MySQL
Mysql 文件配置解析介绍
2022/05/06 MySQL