- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先,如果我重复其他地方发布的内容,我深表歉意。我一直在研究其他人为他们的问题找到的解决方案,并且我已经实现了(或者我认为)他们发现的东西,但我正在开发的网站仍然没有达到预期的效果。
所以,我正在处理的网站是 http://www.vinck-interieur.be/?lang=en .
应该发生的情况是,当向下或向上滚动时,访问者会看到他们在侧边栏菜单中的位置。 ScrollSpy 似乎是执行此操作的最佳选择,但自从我将其放入代码中以来,它一直没有工作。我邀请您查看我在网站中放入的代码,但主要思想如下
<body id="top" <?php body_class(); ?> data-spy="scroll" data-target=".navigation-bar">
<header id="header" class="...">
<div class="bottom-head">
<nav id="access" role="navigation" class="navigation-bar>
<div class="menu-container loaded">
<ul id="menu-main-menu-en" class="top-menu">
<li id="menu-item-672" class="menu-item menu-item-custom menu-item-object-custom menu-item-672 normal-menu">
<a href="#top"><span>home</span></a>
</li>
...
</ul>
</div>
</nav>
</div>
</header>
<div id="mid" class="...">
<article id="content" class="clearfix">
<div id="col-mask">
<div id="post-632" class="...">
<div class="real-content">
<div class="a13_row_container lift-up" style="...">...</div>
<div class="a13_row_container a13_full_row a13_full_content" style="...">...</div>
<div class="a13_row_container lift-up" style="...">...</div>
<div class="a13_row_container a13_full_row a13_full_content" style="...">...</div>
<div class="a13_row_container lift-up" style="...">...</div>
<div class="a13_row_container a13_full_row a13_full_content" style="...">...</div>
...
</div>
</div>
</div>
</article>
</div>
在页脚之后,我首先添加 jQuery,然后调用 Bootstrap,然后使用 JS 将某些 ID 添加到类为“a13_full-row”的每个第二元素:
<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript" src="<?php bloginfo('template_url'); ?>/js/bootstrap.min.js"></script>
<script>
var rows = document.getElementsByClassName("a13_full-row");
for (var i = 0; i < rows.length; i+=2) {
switch(i) {
case 0:
rows[i].setAttribute("id", "home");
break;
case 2:
rows[i].setAttribute("id", "ontwerp");
break;
case 4:
rows[i].setAttribute("id", "project");
break;
case 6:
rows[i].setAttribute("id", "advies");
break;
case 8:
rows[i].setAttribute("id", "portfolio");
break;
case 10:
rows[i].setAttribute("id", "contact");
break;
}
}
}
当我查看网站代码时,这一切都会发生。
然后我使用以下命令刷新滚动 spy :
<script>
jQuery('[data-spy="scroll"]').each(function () {
if(jQuery(this).scrollspy('refresh')) {
console.log("yay");
}
});
<script>
我收到日志消息,因此它应该已刷新。
根据我发现的一切,这应该可行。我已在正文中添加了“数据 spy ”和“数据目标”,因此我不需要暗示滚动条。我已经刷新了滚动 spy ,因此它已更新为添加了 ID 的脚本。...但事实并非如此。谁能帮我吗?
如果需要更多代码,我很乐意提供。
提前致谢。
最佳答案
所以我最终摆脱了 ScrollSpy 并使用 JQuery/JavaScript 作为自定义解决方案。我使用下一个停用功能从菜单中所有项目的类中删除“事件”
函数停用() { var menuItems = document.getElementsByClassName('菜单项');//侧边菜单中的所有
for (var i = 0; i < menuItems.length; i++) {
var menuLinks = menuItems[i].childNodes; // All <a> in <li> in side menu
var tempClass = document.getElementById(menuItems[i].id).className.replace(/active/gi, ''); // replace 'active' by ''
menuItems[i].className = tempClass;
}
}
每次用户滚动时调用未命名的函数:
jQuery(document).on('scroll',function() {
使用“scrollTop()”获取您所查看的内容到页面顶部的偏移量。使用 'offsetTop' 获取该对象到页面顶部的偏移量。
var scrollTop = jQuery(window).scrollTop(), // Position on the page of the top of your window (page offset)
homeOffset = document.getElementById("home").offsetTop, // The offset this element has on the page compared to the top (object offset)
ontwerpOffset = document.getElementById("ontwerp").offsetTop,
projectOffset = document.getElementById("project").offsetTop,
adviesOffset = document.getElementById("advies").offsetTop,
portfolioOffset = document.getElementById("portfolio").offsetTop,
contactOffset = document.getElementById("contact").offsetTop,
获取对象/ anchor 距您正在查看的内容顶部的距离,并使用“Math.abs()”将其设为绝对值。
distHome = Math.abs((homeOffset - scrollTop)), // Absolute value(object offset - page offset)
distOntwerp = Math.abs((ontwerpOffset - scrollTop)),
distProject = Math.abs((projectOffset - scrollTop)),
distAdvies = Math.abs((adviesOffset - scrollTop)),
distPortfolio = Math.abs((portfolioOffset - scrollTop)),
distContact = Math.abs((contactOffset - scrollTop));
记录第二个以进行检查。
console.log("ontwerp: " +distOntwerp);
获取所有偏移量中最小的值并记录下来进行检查
var minOffset = Math.min(distHome, distOntwerp, distProject, distAdvies, distPortfolio, distContact); // The smallest value of them all
console.log("min: " + minOffset);
将此最小值“切换”为每个 anchor 的“案例”(我有一个多语言网站,但不想重复太多,所以我对每种语言的正确菜单项使用“try catch”
switch (minOffset) {
case distHome:
deactivate();
try{
document.getElementById("menu-item-671").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-672").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-673").className += ' active';
} catch(e) {}
break;
case distOntwerp:
deactivate();
try{
document.getElementById("menu-item-54").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-657").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-663").className += ' active';
} catch(e) {}
break;
case distProject:
deactivate();
try{
document.getElementById("menu-item-59").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-658").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-664").className += ' active';
} catch(e) {}
break;
case distAdvies:
deactivate();
try{
document.getElementById("menu-item-56").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-659").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-665").className += ' active';
} catch(e) {}
break;
case distPortfolio:
deactivate();
try{
document.getElementById("menu-item-57").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-660").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-666").className += ' active';
} catch(e) {}
break;
case distContact:
deactivate();
try{
document.getElementById("menu-item-58").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-661").className += ' active';
} catch(e) {}
try{
document.getElementById("menu-item-667").className += ' active';
} catch(e) {}
break;
}
});
关于javascript - ScrollSpy 与脚本添加了 id,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34491439/
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!