jQuery实现导航监听事件
导航html如下
<div class="main_nav">
<a class="nav_01 active_01" href="javascript:;"></a>
<a class="nav_02" href="javascript:;"></a>
<a class="nav_03" href="javascript:;"></a>
<a class="nav_04" href="javascript:;"></a>
</div>
导航css如下
<style>
.main_nav{ width:50px; height:260px; position:fixed; bottom:90px; left:200px;}
.main_nav a{ display:block; width:70px; height:70px; background:#dedede; margin-top:1px; text-align:center; line-height:50px; font-size:18px; background:url(img/nav_bg.png) no-repeat; }
.main_nav .nav_01{ background-position:0px 0px;}
.main_nav .nav_02{ background-position:0px -71px;}
.main_nav .nav_03{ background-position:0px -143px;}
.main_nav .nav_04{ background-position:0px -215px;}
.main_nav .active{ background-position-x:-75px;}
.main_nav .active_01{ background-position:-75px 0px;}
.main_nav .active_02{ background-position:-75px -71px;}
.main_nav .active_03{ background-position:-75px -143px;}
.main_nav .active_04{ background-position:-75px -215px;}
</style>
js代码如下
$(function(){
$(window).scroll(function() {
var scrollHight=$(window).scrollTop();
var mainHight01=$(".main_01").offset().top;
var mainHight02=$(".main_02").offset().top;
var mainHight03=$(".main_03").offset().top;
var mainHight04=$(".main_04").offset().top;
if(scrollHight<mainHight02){
$(".nav_01").addClass("active_01");
$(".nav_02").removeClass("active_02");
$(".nav_03").removeClass("active_03");
$(".nav_04").removeClass("active_04");
}
if(scrollHight>mainHight02&&scrollHight<mainHight03){
$(".nav_01").removeClass("active_01");
$(".nav_02").addClass("active_02");
$(".nav_03").removeClass("active_03");
$(".nav_04").removeClass("active_04");
}
if(scrollHight>mainHight03&&scrollHight<mainHight04){
$(".nav_03").addClass("active_03");
$(".nav_02").removeClass("active_02");
$(".nav_01").removeClass("active_01");
$(".nav_04").removeClass("active_04");
}
if(scrollHight>mainHight04){
$(".nav_04").addClass("active_04");
$(".nav_02").removeClass("active_02");
$(".nav_03").removeClass("active_03");
$(".nav_01").removeClass("active_01");
}
});
$(".main_nav a").each(function(index, element) {
$(this).click(function(){
$("html,body").animate({scrollTop:$(".main_0"+(index+1)).offset().top+20},10);
});
});
});
这里需要说明的是$("html,body").animate({scrollTop:$(".main_0"+(index+1)).offset().top+20},10)这段话里的“.main_0”,这个是在你的页面中需要切换导航锚点的div中需要添加的类名,需要按此格式依次添加如main_01、main_02、main_03
$(".main_0"+(index+1)).offset().top+20中的+20是根据页面实际情况调节的值,主要是为了避免滚动事件和鼠标点击事件保持一致!
jQuery实现导航监听事件的更多相关文章
- jQuery页面滚动监听事件及高级效果插件
jQuery页面滚动监听事件及高级效果插件 1. One Page scroll (只适用于上下焦点图)http://www.thepetedesign.com/demos/onepage_scrol ...
- jquery四种监听事件的区别
最近找工作被问到了jquery有哪些事件监听,都有什么区别,忽然有点想不起来了... 然后上网上查看了相关的资料,总结一下,方便大家查看,也方便自己复习! 1.bind()方法: bind(type, ...
- 避免jquery多次监听事件
jQuery.event.dispatch 事件分发监听源码简单理解是将绑定的事件放入队列后进行监听,如果对一个事件多次绑定(on或者bind),事件会重复添加到队列等待jq监听,这样会导致很大资源消 ...
- jquery实现拖拽以及jquery监听事件的写法
很久之前写了一个jquery3D楼盘在线选择,这么一个插件,插件很简单,因为后期项目中没有实际用到,因此,有些地方不是很完善,后面也懒得再进行修改维护了.最近放到github上面,但是也少有人问津及s ...
- jQuery监听事件经典例子
关键字:jQuery监听事件经典例子 js代码: ============================================================ $(function( ...
- jquery监听事件on写法以及简单的拖拽效果
引子——关于jquery的某些写法 我先不对监听事件做解释,我们先来看下jquery的一些写法吧!我们最常用的是jquery的css()方法,相信大家都会用! 假如用css设置一个属性,我们写法如下: ...
- jquery的监听事件和触发事件
监听事件 $(selector).on('Event me',function(e){ //do something }) 触发事件 $(selector).trigger('Event name') ...
- jquery中,使用append增加元素时,该元素的绑定监听事件失效
举例:如果在一个<div id="resultArea"></div>中,通过append添加一个id="checkOutTip"的文本 ...
- jquery中,使用append增加新元素时,新增元素的绑定监听事件失效的解决办法
$("outerSelector").on("eventType","innerSelector",function(){}); 举例:如果 ...
随机推荐
- c#常见操作
1. StreamWriter - 文件写入类StreamWriter s = new StreamWriter(address + "/Menu.ini", true);s.Wr ...
- Java基础学习笔记1
Dos的基本命令: Dir:列出当前目录的所有文件和文件夹 Md:创建一个目录 Rd:删除目录 Cd:进入指定的目录 Cd..:退回上一级目录 Cd/:退回根目录 Del:删除文件 Exit:退出do ...
- 兼容 CommonJS 和 CommonJS-like规范(1~38)
CommonJS是服务器端模块的规范,Node.js采用了这个规范. 根据CommonJS规范,一个单独的文件就是一个模块.每一个模块都是一个单独的作用域,也就是说,在该模块内部定义的变量,无法被其他 ...
- JavaScript的一点简介(注:本文诸多观点源于JavaScript高级程序设计,如有侵权,立即删除)
JavaScript是一门最易让人误解的语言,该语言中精华与糟粕并存(可能比一般语言的这个比例要大一些):但“千淘万漉虽辛苦,吹尽黄沙始到金”,层层面纱下是易用灵活.优雅轻灵的内在.很久以前,Java ...
- js对表单设置了readonly和disabled后的区别
Readonly和Disabled是用在表单中的两个属性,它们都能够做到使用户不能够更改表单域中的内容.但是它们之间有着微小的差别,总结如下: 1)Readonly只针对input(text / pa ...
- JAVA注释方式--目前用的
代码整洁,规范,可读,注释是关键之一. 1.整个类文件注释 注释结构:/* * @(#){类名称}.java {创建时间} * * {某人或某公司具有完全的版权} * {使用者必须经过许可 ...
- QF——关于iOS的强引用,弱引用及strong,retain,copy,weak,assignd的关系
强引用和弱引用: 我们已经知道OC中的内存管理是通过“引用计数器”来实现的.一个对象的生命周期取决于它是否还被其他对象引用(是否retainCount=0).但在有些情况下,我们并不希望对象的销毁时间 ...
- 动态include与静态include的区别
搬一下以前写的 个人总结: 动态INCLUDE 用jsp:include动作实现 <jsp:include page="included.jsp" flush="t ...
- struts中简单的校验
Struts中简单的校验 “计应134(实验班) 凌豪” Struts2校验简要说明:struts2中通常情况下,类型转换要在数据校验之前进行.类型转换其实也是基本的服务器端校验,合法数据必然可以通过 ...
- zabbix 的安装
第一步:官方的源: rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/7/x86_64/zabbix-release-2.4-1.el7.noarch.r ...