【一天一道兼容性】之——IOS4及以下fixed失效
生活随笔
收集整理的这篇文章主要介绍了
【一天一道兼容性】之——IOS4及以下fixed失效
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
少叙闲言
如今手机换代都快赶上换衣服速度了,每每出新手机都是各种搭载最新系统,大家都在关心android5.0该不该叫切糕?IOS的最新版啥时候出完美越狱……,可偏偏就总有些人抱着旧系统来测你的页面,没有那金刚钻,还非要揽这瓷器活?!android碎也就那么地了,你苹果来凑什么热闹啊……,今儿接到个任务,说是领导家有个亲戚,上我们时候首页的一个fixed元素在ios旧版本中失效,让做兼容……,好吧,为了什么鬼亲戚,我只能蝴蝶效应了……
正题
demo:
<style>html, body, div, p {margin: 0;padding: 0; }body {height: 3000px;background-color:#a55;}#p {width: 100%;height: 50px;background: #5a5;position: fixed;bottom: 0;} </style> <body><p id = "p"></p> </body>
如图:(模拟失效环境)
解析问题:
1:IOS5以下版本的safari不支持fixed
2:android据说2.0以上就支持fixed,但我测试时候发现,2.2的i9000上,测试页好使,但线上大量数据时候失效,可能由于搭载的硬件关系导致。
解决办法:
利用position:absolute;bottom:0和scroll事件进行模拟fixed,另外,当触发touchstart时候,浏览器会暂停页面渲染,也就是我们看到的截屏效果,所以,为了滚动时候不影响美观,所以先将其隐藏掉,事后再放出来。
1 <script> 2 var android2_3up = navigator.userAgent.match(/Android [2-9].[3-9][.\d]*/); 3 var ios5up = navigator.userAgent.match(/OS [5-9]_\d[_\d]*/); 4 var isMobile = !!navigator.userAgent.match(/AppleWebKit.*Mobile.*/); 5 if (isMobile && !ios5up || !android2_3up) {//匹配ios4 或android2.3以下 6 var p = document.getElementById("p"); 7 p.style.display = "absolute"; 8 function handler(event) { 9 var top = window.innerHeight + document.body.scrollTop - 50; 10 p.style.top = top + "px"; 11 p.style.opacity = 1; 12 } 13 function touchstart(event) { 14 p.style.opacity = 0; 15 } 16 function touchend(event) { 17 p.style.opacity = 1; 18 } 19 document.addEventListener("scroll", handler, false); 20 document.addEventListener("touchstart", touchstart, false); 21 document.addEventListener("touchend", touchend, false); 22 } 23 </script>
转载于:https://www.cnblogs.com/ccto/archive/2013/04/18/3029237.html
总结
以上是生活随笔为你收集整理的【一天一道兼容性】之——IOS4及以下fixed失效的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: Http协议中的各种长度限制总结
- 下一篇: AUTOCAD自学教程一