- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一种感觉,是什么给我带来了问题,我试图在这个问题中找到解决方案 - Can't trigger a jquery function with scroll on a particular div - 可能负责此处滚动相关的问题。
简短版本:无法使这个或类似的东西工作
$("#Container3").scrollTop(0);
实际上什么都没有发生,控制台中没有错误,没有奇怪的行为,只是似乎忽略了 scrollTop(0) 请求。
长版:很抱歉,发布代码片段是不可行的,因为它是一个类似应用程序的复杂界面,但我会尽力解释这个问题:
加载是在视口(viewport)之外完成的,因此不需要动画,但只要它们能够正常工作,我就会使用它们。
这就是我的 jquery 请求的样子
$(document).on("click",".NavRowButton",function(event){
$("#Container3").scrollTop(0);
var $targetButtonId=$(event.target).attr("id");
$("#Content").load("/load/login/"+$targetButtonId+".php");
$("#DisplayContentName").html("<span class='NavColSpan'>"+$targetButtonId+"</span>");
$("#Container3").find(".WindowBorder").css("top","0");
});
#Container3 有滚动条并且是#Content 的直接父级。
这是一个我仍在构建的函数,它是我之前遇到的问题的解决方案,也是我现在用来帮助调试这个问题的方法:
document.addEventListener('scroll',function(event){
if(event.target.className==='Container'){
var $currentScroll=$(event.target).scrollTop();
console.log($currentScroll);
var $targetId=$(event.target).attr("id");
console.log($targetId);
}
},true);
提前致谢。
编辑: 我刚刚注意到,如果我放一个 $(event.target).scrollTop(0);在滚动距离调试功能的末尾,它实际上重置了滚动,所以看起来只要 div 是 event.target 它就可以工作,而在点击功能期间从外部我可能没有正确选择它。
Edit2: 我刚刚了解到我可以将 event.targets 缓存到变量中,并在点击函数中使用 .get() 我确定我选择了正确的元素,所以它只剩下如何scrollTop(0) 方法有效。
它们现在看起来像这样(还必须添加一个条件来限制加载事件):
全局变量:
$DivTestVar="";
点击:
$(document).on("click",".NavRowButton",function(event){
var $targetButtonId=event.target.id;
if($targetButtonId != $("#DisplayContentName").html()){
$($DivTestVar).scrollTop(0);
console.log($($DivTestVar).get());
$("#Content").load("/load/login/"+$targetButtonId+".php");
$("#DisplayContentName").html($targetButtonId);
$("#Container3").find(".WindowBorder").css("top","0");
};
});
滚动调试:
document.addEventListener('scroll',function(event){
if(event.target.className==='Container'){
$DivTestVar=event.target;
var $currentScroll=$($DivTestVar).scrollTop();
console.log($currentScroll);
var $targetId=event.target.id;
console.log($targetId);
}
},true);
如果我在滚动之前单击 console.log($($DivTestVar).get());返回空,但如果在第一次滚动时它开始返回正确的 DOM 元素。 scrollTop(0) 无论如何都会被忽略。
Edit3:我只想留下一个小更新。从那以后,我放弃了我在这里尝试使用的方法,以获得类似效果但不像我试图实现的那样用户友好。因此,我个人不再关心这个问题,但如果你正在阅读这篇文章并遇到类似的问题,我已经多次遇到过这个问题,但影响较小,我现在认为它与 position:fixed; 有关。元素以及 scrollTop() 如何处理它,但我没有时间深入研究它,祝你好运,一切顺利。
最佳答案
你试过纯JS版本吗?
document.getElementById('Container').scrollTop = 0
关于javascript - .scrollTop(0) 无法让 div 滚动到顶部,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32952341/
我收到错误: body.scrollTop 在严格模式下已弃用。请在严格模式下使用“documentElement.scrollTop”,在怪异模式下使用“body.scrollTop”。 我的代码是
两者有什么区别: $(window).scrollTop() 和 $(document).scrollTop() 谢谢。 最佳答案 它们都有相同的效果。 但是,正如评论中所指出的: $(window)
我不太明白这一点,因为有时 body,html 有效,有时 window.我已经用 jQuery 完成了 2 个网页(本地);在第一个主体中,html 可以工作,而在另一个主体中则不行,所以我编写了
我遇到了一个仅在 Safari 中发生的问题。我有一个特定的 div,我试图在页面加载后自动滚动到特定位置。 如果我在 Safari 中输入页面的 URL 并按 Enter 键,则 div 无法正常滚
我有这段代码,我想在 div 而不是正文上滚动 var scrollPosition = document.body.scrollTop || document.documentElement.scr
我是 jQuery 的新手,所以请不要介意我。 我有这个风格 html, body{ height: 100%; overflow: auto; } 还有这个脚本 $(document
我只想获取文档的滚动条并使用此 answer 中的代码.但我得到的是一个“窗口”对象。我已经用 IE 10、Chrome 和 Firefox 进行了测试。这是我的代码: var doc = d
当试图找出网页从顶部滚动了多少时,应该使用以下哪一个: document.body.scrollTop, document.documentElement.scrollTop, window.page
我有一个导航,初始网址如下所示: test.php?query=19 我的页面上有像这样的链接 Section 1Section 2Section 3 分为 3 个部分: 并且我正在使用此 jque
如何在没有动画的情况下使用滚动顶部 此代码有效: var offTop = $('#box').offset().top; offTop = offTop-43; $('#mainCt').anim
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
当我使用函数scrollTop 获取顶部的像素数时,我收到的像素数为1、4、20...,具体取决于我滚动的速度。 $(window).scroll(function(){ var positi
嘿,我试图通过向左移动 10% 和向右移动 10% 来让 2 个 div 相互移开。在 1000 点之后它们会相互移开,但在我向后滚动到 1000 点之前它们不会再移回来 $(document).re
我有一些带有 .class 类的 div,其滚动位置由其父级的另一个子级定义,因此我需要分配一个 scrollTop () 与 $(this),类似 $(".class").scrollTop($(t
我在使用 ScrollTop 效果时遇到一些困难。事实上,它不起作用,我也不明白为什么。 这是我的代码的 Javascript 部分: $('.hcb_link').click(function(){
我想将自定义滚动写入部分功能。 当我加载页面并向下滚动时,它应该向下滚动窗口的高度,这很好。 然后,如果再次向下滚动,我想检查页面是否滚动超过窗口高度(如果向下滚动,则应该是),但它似乎卡在第一次滚动
我得到了下面的函数,该函数会弹出一个窗口,但无法将主页滚动到适当的 div 高度。 function open_window(getDiv) { var objDiv = document.getEl
我编写了这段代码来计算到页面顶部的距离。根据距离是否为 0,它会使图像消失/出现,并向上/向下移动辅助图像。 $(window).scroll(function(){ if ($(this).
我正在努力让scrolltop()返回一个值。现在它只给出 0。我知道这是一个简单的问题,但有人有任何建议吗? 这是 JQuery: $(document).ready(function(){ $('
我在此菜单上使用 jQuery 滚动顶部功能:http://goethesternfriseure.de/index.php 问题是滚动功能仅在第一次起作用。第二次点击链接后,它会滚动到底部。 $('
我是一名优秀的程序员,十分优秀!