下载鸥 > 网站下载 > 开发教程 > 前端开发

自动切换导航高亮效果(基于jQuery)

374 2021-09-05 15:35:05

收藏
在一些单页面站点中,网站的各个主模块都在同一个页面,点击导航可以页面内跳转,在滚动时可以自动切换导航的高亮效果。这个功能要怎样实现呢?

自动切换导航高亮效果(基于jQuery)

html代码1 - 导航

<div class="head">
  <ul>
    <li class="on"><a href="#dx1">首页</a></li>
    <li><a href="#dx2">产品展示</a></li>
    <li><a href="#dx3">案例展示</a></li>
    <li><a href="#dx4">关于我们</a></li>
    <li><a href="#dx5">联系我们</a></li>
  </ul>
</div>
 

html代码2 - 模块

<div class="temp" id="dx1">首页相关模块</div>
<div class="temp" id="dx2">产品展示相关模块</div>
<div class="temp" id="dx3">案例展示相关模块</div>
<div class="temp" id="dx4">关于我们相关模块</div>
<div class="temp" id="dx5">联系我们相关模块</div>
 

CSS代码

.head ul li{
    background:#999
}
.head ul li.on{
    background:#333
}
 

jQuery代码

<script type="text/javascript">
$('.head li a').click(function(){
	$('html,body').animate({
	    scrollTop:$($(this).attr('href')).offset().top - 80}, 300);
});	
fxtop();
function fxtop(){
	$(window).bind("scroll", function(event) {
		if($(window).scrollTop()>=$('.head').offset().top){
			$(".head").addClass('ons');
		}else{
			$(".head").removeClass('ons');
		} 
		var list = $('.temp');
		var tt = $(window).scrollTop()+$('.head').height();
		var aa = $('.head li');
		list.each(function(index) {
			if ($(this).offset().top <= tt && tt < $(this).offset().top + $(this).height()) {
				var id = $(this).attr('id');
				aa.each(function(i){
					var a = $(this).find('a').attr('href');
					if('#'+id == a){
						$(this).addClass('on');
					}else{
						$(this).removeClass('on');
					}
				});
				return false
			}
			
		})
	});
}
</script>
注意,jQuery代码开始之前要引入jQuery库,否则无效。

这样,我们就实现了导航高亮效果随鼠标滚动发生变化,点击导航也可以自动跳转到对应的区域。

本文地址:https://xzo.com.cn/develop/js/1047.html

有帮助,很赞!

信息来源:下载鸥
导出教程 下载word版教程
发表评论 共有条评论
关于前端开发


JavaScript(简称“JS”) 是一种具有函数优先的轻量级,解释型或即时编译型的编程语言。JavaScript 基于原型编程、多范式的动态脚本语言,并且支持面向对象、命令式和声明式(如函数式编程)风格。

JavaScript十分强大,不管是前端页面开发、视觉动态渲染、数据交互还是后端逻辑处理,都可以通过JS实现。虽然它是作为开发Web页面的脚本语言而出名,但是它也被用到了很多非浏览器环境中。

推荐前端开发开发教程
JS验证手机是否11位的做法
JS验证手机是否11位的做法

在网站表单提交前,我们往往需要验证一下信息避免错误数据,那么,怎样验证手机号...

1 389
jQuery怎样监听鼠标滚动是向上还是向下的状态?
jQuery怎样监听鼠标滚动是向上还是向下的状态?

知乎鼠标向下滚动显示文章标题,向上滚动显示栏目;又或者向下滚动到底部时异步...

0 522
JS获取当前时间、日期、星期并每秒更新一次
JS获取当前时间、日期、星期并每秒更新一次

很多网站上会有当前年月日、星期、时间的展示。这个展示用php做未免浪费性...

0 374
$(window).height() 和 $(document).height()有什么不同?
$(window).height() 和 $(document).height()有什么不同?

我们常用$(window).height() 和 $(document).height()来监听当前高度,但这个...

1 369
swiper轮播图空白案例记录
swiper轮播图空白案例记录

今天鸥哥在用swiper做轮播图时,轮播效果虽然没问题,但只显示第一张,后面的图片...

0 345
jQuery监听点击事件弹出关注二维码教程
jQuery监听点击事件弹出关注二维码教程

通过jQuery实现点击关注按钮弹出二维码是一个比较常用的功能,今天鸥哥讲讲这...

0 446
js网站视频播放器ckplayer和dplayer优缺点分析
js网站视频播放器ckplayer和dplayer优缺点分析

dplayer和ckplayer都是非常流行的web视频播放器,二者都占有相当大的用户市场...

0 1513
jQuery怎样给图片添加默认域名?
jQuery怎样给图片添加默认域名?

在很多网站中,图片的默认路径是相对于根目录的绝对路径,如果是其他站点引用,则...

0 416
推荐插件
帝国cms百度AI图像无损放大api接口对接插件
帝国cms百度AI图像无损放大api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像无损放大的功能。经过...

0 390
帝国cms批量添加后台用户插件
帝国cms批量添加后台用户插件

使用帝国cms的企业用户、新闻资讯类站点的用户很多,此类站点很多时候需要有...

0 664
帝国cms网站会员登录与退出历史记录日志插件
帝国cms网站会员登录与退出历史记录日志插件

帝国cms默认只有上次登录时间与ip,没有一个记录清单,所以今天,我们分享这个帝...

0 352
帝国cms纳米数据接口(足球比赛中最新数据)
帝国cms纳米数据接口(足球比赛中最新数据)

帝国cms 对接纳米数据(www.nami.com)接口,本接口主要接收、整理足球比赛实时数...

0 284
帝国cms访问统计ip地址链接与封禁插件下载
帝国cms访问统计ip地址链接与封禁插件下载

下载鸥开发了这款帝国cms封禁ip插件,自动记录访问情况,让我们可以更快的识别...

0 936
帝国cms百度AI黑白图像上色api接口对接插件
帝国cms百度AI黑白图像上色api接口对接插件

百度开放了系列AI功能api如图像上色、图像去雾、图像修复、无损放大、清晰...

0 365
帝国cms智能自动审核按星期几审核指定栏目带推送插件
帝国cms智能自动审核按星期几审核指定栏目带推送插件

采集站的必备资源是自动审核,要做到日收录也离不开定时发布。而本插件的自动...

0 1199
帝国CMS内网用户静态站点文章访客统计插件
帝国CMS内网用户静态站点文章访客统计插件

本插件适用于内网用户,可查看单篇文章访问者ip地址。如果添加访问者ip组,可查...

0 496
客服QQ:341553759
扫码咨询 常见问题 >
官方交流群:90432500
点击加入