- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Bootstrap 3,我有一个全屏旋转木马,后面有一个导航栏。用户完全滚动经过轮播后,导航栏会固定在顶部。这很好用。
但是现在当用户几乎不向下滚动然后向上滚动时,导航栏不会回到原来的位置,它会固定在顶部。
这是我的 js:
$(function() {
var lastfixed = undefined,
spacerEl = undefined,
fixed = false,
ghostElHeight = 0;
$(document).on('scroll', function() {
console.log('scroll top : ' + $(window).scrollTop());
if ($(window).scrollTop() >= $(".carousel").outerHeight()) {
fixed = true;
if (fixed === lastfixed) return
$(".navbar").addClass("navbar-fixed-top");
ghostElHeight = $(".navbar").outerHeight()
if (!!!spacerEl) {
spacerEl = $(".navbar").after(
'<div class="navspacer" style="height:' + ghostElHeight + 'px"> </div>').next();
}
}
if ($(window).scrollTop() < $(".carousel").height() + ghostElHeight) {
fixed = false;
if (fixed === lastfixed) return
ghostElHeight = 0;
$(".navbar").removeClass("navbar-fixed-top");
!!spacerEl && spacerEl.remove();
spacerEl = undefined;
}
lastfixed = fixed;
});
});
我还创建了一个 fiddle :http://jsfiddle.net/thqx9g9b/2/为了重现错误,您可能需要单击滚轮,在导航栏固定到顶部后向下滚动一点点,然后向上滚动。
奇怪的是我正在做同样的事情,但是有一个全屏超大屏幕并且没有出现错误。
更新:如果我在 .carousel 类上添加“padding:55px”,问题就会消失。但是,如果我在轮播中使用图像,这会导致出现大边框。
这是带有填充的更新 fiddle :http://jsfiddle.net/thqx9g9b/3/
这在我的带有超大屏幕的版本上有效的原因是因为图像设置在父 div 上并且没有由填充引起的边框,我试图在旋转木马内的各种元素上放置填充但是对于它需要在父 div 上才能工作,有人对此有某种解决方法吗?还是我遗漏了什么?
最佳答案
目前您的算法似乎有点偏差。
现在,如果您只滚动到低于 $(".carousel").outerHeight() 一点
-> fixed 不成立,因此导航栏永远不会丢失 navbar-fixed-top
类。
你必须改变这个
if ($(window).scrollTop() < $(".carousel").height() + ghostElHeight) {
到
if ($(window).scrollTop() < $(".carousel").height()) {
然后它按预期工作。当然你不必再乱用 ghostElHeight
了。只需在 HTML 中添加 navspacer 并使用显示/隐藏切换它。
还有一个问题:你引入了一个变量lastfixed
,这使得代码变得复杂。没有 lastfixed
的更好方法:
改变你的算法
fixed = true;
if (fixed === lastfixed) return
到
if (fixed == true) return
fixed = true;
假部分也一样。这更容易也更清楚。
完整的JS代码:
$(function () {
var fixed = false;
$(document).on( 'scroll', function(){
if($(window).scrollTop()>=$(".carousel").outerHeight())
{
if (fixed == true) return
fixed = true;
$(".navbar").addClass("navbar-fixed-top");
$(".navspacer").show();
}
if($(window).scrollTop()<$(".carousel").height())
{
if (fixed == false) return
fixed = false;
$(".navbar").removeClass("navbar-fixed-top");
$(".navspacer").hide();
}
});
});
并在导航栏之后手动添加navspacer:
<div style="height:100px; display: none;" class="navspacer"> </div>
关于jquery - Ghost dom element navbar fixed top不停留在原位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31844980/
下面两个CSS选择器有什么区别? 来自解释here ,它们听起来一样吗? div p{} 选择div元素内的所有p元素 div > p{} 选择父级为 div 元素的所有 p 元素。 最佳答案 区别在
我需要怎么做: 目前,事实证明: 我更喜欢它看起来像: 最佳答案 有了这些空行,看起来您的 select 语句是(正确地)选择您
用替换元素是否有效至 .在这种情况下,我想要, 这样我就可以在...中附加验证数据。这也可以从 中实现吗?或 等等? 最佳答案 标签没有 而且不需要一个。同样适用于 和 .您可以将验证数据作为
我刚刚发现了 Angular 1.2.1 的一个奇怪问题,在 this fiddle 中进行了演示。 (在 IE、FF 和 Chrome 中测试):如果我创建一个非常简单的模板化指令,它无法像 那样
我正在尝试使用 Jsoup 迭代 java 中的两个元素,但是,我收到运行时异常错误。看来我无法将nodes.Element 的类型转换为element.Element。 非常感谢您的帮助,谢谢。 代
假设我的文档中有一组元素,它们是单个对象的子元素。这些元素中的每一个都使用不同的参数注册一个新的事件监听器。如果我丢弃父对象,是否需要手动取消注册所有 eventListener?或者浏览器是否跟踪所
我不应该在我的应用程序中使用 jQuery,但我有一个场景,我需要元素的偏移量,而不是使用 $(element).offset() 我已经使用了 angular.element(element).of
我是TS的新手,我想知道为什么我在以下代码中遇到类型错误(简化):。错误在`{iconMap[名称]}中:。“元素隐式具有‘any’类型,因为‘字符串’类型的表达式不能用于索引类型‘{Categori
我是TS的新手,我想知道为什么我在以下代码中遇到类型错误(简化):。错误在`{iconMap[名称]}中:。“元素隐式具有”any“类型,因为”string“类型的表达式不能用于索引类型”{ Cate
什么意思: Separator.Iterator.Element == Self.Iterator.Element.Iterator.Element 在this (Swift 标准库)swift 实例
是否可以在 img 元素上使用前后伪选择器?认为它是但没有任何运气,将 css 切换到 div 并且它工作正常。 .page-overhang 类是 img 元素。 // page overhang
我在 UI 中的按钮 Click 事件上有以下代码,它返回一个 MS-Excel 文件。它在第一次点击事件中完美运行,但之后返回以下错误。 任何建议,我怎样才能摆脱它? ERROR: Uncaught
如何在 CSS 中编写这个想法: 选择 ElementA 内但不在 ElementB 内且 ElementB 在 ElementA 内的每个元素。 这是一个例子:
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
如果我在 C# 中的 XElement myXML 变量中有以下 XML, myvalue 要获得“myvalue”,我需要执行以下操作: myXML.Element(
我找不到用户名和密码字段。我检查元素,并尝试通过 id、xpath 或 css 选择器查找它,但它给出错误 NoSuchElementException: Message: no such eleme
我的任务是在用户点击它时从输入框中删除占位符并使标签可见。如果用户未在其中再次填写任何内容,请放回占位符并使标签不可见。 我可以隐藏它但不能重新分配它。我试过 element.setAttribute
我正在编写一个 c# 类来编写一个 XML 文件,该文件需要与我们使用的现有 XML 的结构完全匹配,这样一些遗留系统就不会混淆。 当一个元素的InnerText值为null时,我需要xml元素的元素
自定义元素的一个常见做法,至少在 Polymer(最流行的 Web 组件框架)中,是定义一个新的自定义元素。恕我直言,这对 来说不是一个好习惯呈现 元素,因为该元素无法逐步呈现,必须等到它被加载(注册
我正在尝试跟踪元素的可见性及其显示的控制台错误:“元素“a[data-vars-ei]”必须是 AMP 元素”。 但是在点击跟踪的情况下,类似的事情工作正常。 我无法理解为什么会发生这种情况以及我应该
我是一名优秀的程序员,十分优秀!