现在苹果手机究竟苹果6s该不该升ios11用了

JS中完美兼容各大浏览器的scrolltop方法
投稿:hebedich
字体:[ ] 类型:转载 时间:
最近用到scrolloTop()想去获取滚动条距离顶部的距离,结果只有chrome下面可以正常的获取scrollTop,ff和ie下这个值都等于0,使得许多效果比如屏幕滚动等等均无法正常实现。究其原因是scrollTop()在各个浏览器中的兼容性问题,今天我们就来详细探讨下。
1、各浏览器下 scrollTop的差异
IE6/7/8/9/10:
对于没有doctype声明的页面里可以使用& document.body.scrollTop 来获取 scrollTop高度 ;
对于有doctype声明的页面则可以使用 document.documentElement.scrollTop& ;
safari 比较特别,有自己获取scrollTop的函数 : window.pageYOffset ;
火狐等等相对标准些的浏览器就省心多了,直接用 document.documentElement.scrollTop ;
2、获取scrollTop值
完美的获取scrollTop 赋值短语 :
var scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollT
通过这句赋值就能在任何情况下获得scrollTop 值。
仔细观察这句赋值,你发现啥了没??
没错, 就是 window.pageYOffset& (Safari)&& 被放置在 || 的中间位置。
因为当 数字0 与 undefine 进行 或运算时,系统默认返回最后一个值。即或运算中 0 ==
当页面滚动条刚好在最顶端,即scrollTop值为 0 时,IE 下 window.pageYOffset& (Safari) 返回为 undefine ,此时将 window.pageYOffset& (Safari) 放在或运算最后面时, scrollTop 返回 undefine ,& undefine 用在接下去的运算就会报错咯。
而其他浏览器 无论 scrollTop 赋值或运算顺序如何都不会返回 undefine.& 可以安全使用..
所以说到头还是IE的问题咯. 杯具…
精神有点恍惚,不知道有没有表达清楚。
不过最后总结出来这句实验过OK,大家放心使用。
var scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollT
这是完美的获取scrollTop赋值语句。
以上所述就是本文的全部内容了,希望大家能够喜欢。
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具正文 jQuery动画效果animate和scrollTop结合使用实例
jQuery动画效果animate和scrollTop结合使用实例
发布时间: & 编辑:
animate是jq的一个特效的函数方法,animate() 方法执行 CSS 属性集的自定义动画。该方法通过CSS样式将元素从一个状态改变为另一个状态。
$('#shang').click(function(){$('html,body').animate({scrollTop: '0px'}, 800);});上面的代码表示滚动条跳到0的位置,页面移动速度是800。结合scrollTop实用示例:复制代码 代码如下:(document).ready(function($){&$('#shang').click(function(){&&$('html,body').animate({scrollTop: '0px'}, 800);&});&$('#comt').click(function(){&&$('html,body').animate({scrollTop:$('#comments').offset().top}, 800);&});&$('#xia').click(function(){&&$('html,body').animate({scrollTop:$('#footer').offset().top}, 800);&});});表示点击相关ID移动到指定位置:点击ID为shang的元素,回到顶部;点击ID为comt的元素,回到ID为comments的位置;点击ID为xia的元素,回到底部;
您可能感兴趣的文章:如何在jQuery框架下运用$(window).scrollTop(0);使滚动条有缓冲的回到顶部
$("html,body").animate({scrollTop:0},300);为什么把$("html,body")换成$(window)就没效果了呢?
写下你的评论...
写下你的评论...
写下你的评论...
Copyright (C)
All Rights Reserved | 京ICP备 号-2慕课网首席鞭挞师!
请 点击查看文档
你还没有登录,请先登录或注册慕课网帐号
21493人关注
53635人关注
Copyright (C)
All Rights Reserved | 京ICP备 号-2类似问题 &
JavaScript &&&&最新内容
JavaScript &&&&相关内容}

我要回帖

更多关于 苹果手机程序开发 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信