ScrollTop适用于Chrome和Edge,但不适用于Firefox
ScrollTop works in Chrome and Edge but not Firefox
所以我有一个JavaScript函数,当点击导航栏的那一部分时,它会滚动到所需的元素。它在Chrome和Edge中运行良好,但在Firefox或IE中则不然。
功能:
$('html', 'body').animate({
scrollTop:$('.'+nextView).offset().top}, 1500
);
nextView
是来自另一个函数的变量,它确定导航的哪个部分被点击。基本上,它包含要滚动到视图中的div的名称。
有人知道为什么它不起作用吗?还是一种可行的自动滚动的替代方法?
尝试.position()而不是.offset(),看看这是否有效。可能需要一些更正。
编辑:这可能与你的选择器有关。使用html,正文为1字符串:
$('html, body').animate({
scrollTop:$('.'+nextView).offset().top}, 1500
);
我对代码做了一点更改,现在它似乎可以工作了。在animate调用之前,我找到了要滚动到的元素的位置,然后将该变量放入scrollTop,它现在就可以工作了,甚至在IE中也是如此!
scrollPos = $('.'+nextView).offset().top;
$('html, body').animate({
scrollTop: scrollPos
}, 1500);
相关文章:
- HTML5 Canvas toDataURL(“image/png”)适用于一些绘画,而有些则不然,不确定原因
- JavaScript不显示剩余字符,但适用于其他页面
- 我如何完善这个Javascript代码,使其只适用于来自图像的链接(而不是来自文本的链接)
- 为什么这只适用于身体部分而不是头部
- 为什么不't此正则表达式适用于重复出现的对
- document.getElementById 对内部 html 的调用适用于 $_POST 和 $_GET 变量,但不
- JavaScript 位置适用于本地主机而不是服务器
- Rally App SDK 2.0:Rallymultiobjectpicker,适用于不显示displayField的
- jQuery事件在Mozilla上不起作用,并且适用于其他浏览器
- Angular.js - 控制器不为索引执行,适用于其余模板
- D3 .on 更改适用于文本而不是图表
- Zillow 数据 - json_encode不起作用 - 适用于常规变量
- 弹出模式仅适用于表格中的第一个元素,第二次单击后不会再次打开
- Phonegap Android项目适用于模拟器,而不是实际的手机
- ajax jonp 不应该适用于 请求的上不存在“访问控制-允许源”标头
- AngularJS:ng-单击不起作用,适用于<按钮>
- Javascript不会在移动设备上加载.适用于桌面
- 为什么我的代码适用于高度:100px,而不是高度:100%
- 拖放区.js + Laravel-多文件上传不起作用(仅适用于一个文件)
- 哪些限制适用于不透明响应