一种快速实现滑屏页面布局的方法(使用JavaScript实现滑动门效果)
一种快速实现滑屏页面布局的方法
现在越来越多的展示型移动端页面会使用滑屏切换的方式来展示内容,滑屏最重要的是每一个页面是全屏展示,但是移动端的分辨率又非常多,所以如何小成本地实现全屏是一个重点,这里使用百分比布局
先来看一下效果:
1、HTML代码:
2、CSS代码:
在body下的DIV的高度各为100%,宽度是可以占满整个窗口宽度,但是高度是不生效的,这是因为高度的百分比是继承自父元素的,而父元素body的高度是默认根据内容延伸的,所以需要通过设置html,body{height:100%},来使div的height:100%生效。
我们将\".wrap2\"的高度设为1000%,使wrap2的高度等于10个屏幕的高度。然后将\".page\"的高设置为10%,也就是1/10个wrap2的高度,即1个屏幕的高度。
通过上面的代码,就能很轻松地让每个页面都全屏显示,并且不会让浏览器出现滚动条。如果是左右切换的,同理,将所有DIV的高度都设为100%,\".wrap2\"的宽度设为1000%,\".page\"的宽度设为10%并且float:left。
3、JavaScript代码:
总结:
因为最外层DIV设置了overflow:hidden,浏览器默认的滑动也无法使用了,所以需要用JavaScript来实现滑动。当手指还在滑屏且没有离开屏幕时,通过记录手指在屏幕上的位移量,并同步设置wrap2的位置。由于每屏\".page\"都是在wrap2这个DIV里的,当手指离开屏幕时(touchend),根据手指滑动方向来控制wrap2的定位进行上下页的切换,例如:当切换到第2页就是控制translateY为-100%,第3页就是控制translateY为-200%。
使用JavaScript实现滑动门效果
如何使用JavaScript实现滑动门效果呢?今天小编为大家分享一下。
首先我们需要把握实现滑动门所需技术:
1、简单的HTML基础知识
2、简单的CSS基础样式
3、基本的javascript知识
(推荐教程:javascript教程)
再来看看最终实现方法
HTML
1 2 3 4 5 6 |
<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
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
*{ 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
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
//加载dom树 window.onload = function(){ //定义盒子 var box=document.getElementById(\'container\'); //定义图片 var imgs=box.getElementsByTagName(\'img\'); //图片宽度 var imgWidth = imgs[0].offsetWidth; //隐藏宽度 var exposeWidth = 210; //盒子宽度 var boxWidth = imgWidth + (imgs.length -1) * exposeWidth; box.style.width=\'px\'; //设置每道门的初始位置 function SetImgsPos(){ for(var i = 1;i<imgs.length;i++){ imgs[i].style.left = imgWidth + exposeWidth*(i -1)+ \'px\'; } } 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 + \'px\'; } } })(i); } } |
以上就是js如何实现滑动门效果的详细内容,更多请关注php中文网其它相关文章!
1. 带 [亲测] 说明源码已经被站长亲测过!
2. 下载后的源码请在24小时内删除,仅供学习用途!
3. 分享目的仅供大家学习和交流,请不要用于商业用途!
4. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
5. 本站所有资源来源于站长上传和网络,如有侵权请邮件联系站长!
6. 没带 [亲测] 代表站长时间紧促,站长会保持每天更新 [亲测] 源码 !
7. 盗版ripro用户购买ripro美化无担保,若设置不成功/不生效我们不支持退款!
8. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
9. 如果你也有好源码或者教程,可以到审核区发布,分享有金币奖励和额外收入!
10.如果您购买了某个产品,而我们还没来得及更新,请联系站长或留言催更,谢谢理解 !
GG资源网 » 一种快速实现滑屏页面布局的方法(使用JavaScript实现滑动门效果)