100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > 如何利用JavaScript实现导航栏悬停效果的图文代码详解

如何利用JavaScript实现导航栏悬停效果的图文代码详解

时间:2022-01-30 06:31:27

相关推荐

如何利用JavaScript实现导航栏悬停效果的图文代码详解

web前端|js教程

JavaScript,js,导航

web前端-js教程

上次导航栏悬停的那个页面在IE上运行的时候,会出导航栏不停的抖动问题,在本文已有完美的解决方法,将导航栏的定位方式由原来的absolute改为fixed即可

房产网 源码,ubuntu挂载目录更改,提高python爬虫速度,穿透 php,seo优化总部lzw

上次【JS-实现导航栏悬停】说到,导航栏悬停的那个页面在IE上运行的时候,会出导航栏不停的抖动问题。

帝友p2p借贷系统源码解压密码,怎样用vscode模仿网页文字,ubuntu qmake,tomcat中的jre在哪,sqlite存储的,优秀的网页设计策划提案,云虚拟主机服务器,discuz 插件应用破解,大厂用前端框架,反爬虫爬取,centos搭建php环境,上海网站seo优化方案,百变flash网站管理系统,网页右菜单源码,dede留言板模板,js点击页面置顶,文章管理系统带api,易语言定时执行子程序lzw

解决方法如下:

在线祭祀网站 源码,vscode使用iar,ubuntu重启防火墙,tomcat流量,sqlite访问dll,云服务器怎么设置ftp密码,jq预加载插件,c s框架 前端,网络爬虫 电商,php 递归,武汉seo网站优化,网站前台 下载,网页设计中文模板,大数据后台模板,个人超碰黑色登录页面,南方数据企业网站管理系统破解,易语言保存程序失败lzw

将导航栏的定位方式由原来的absolute改为fixed,也不知道为什么改为fixed,就不抖了。。-_-||

p.navigation{ width: 800px; height: 40px; background: red; margin: 4px auto 0; top: 400px; left: 0px; position: fixed; }

为此,JS也得做相应的修改。

因为fixed定位是根据浏览器的可视区进行定位的,所以原来给导航栏的定位都得改变。

//记录导航条原来在页面上的位置 var naviga_offsetTop = 0; var naviga_offsetLeft = 0; //IE7不识别getElementsByClassName,为了兼容自定义一个 function my_getElementsByClassName(class_name) { var el = []; //获取所有元素 _el = document.getElementsByTagName(*); //通过className刷选 for (var i=0; i naviga_offsetTop ){ a_navigation_bar[0].style.top = 0 + "px"; } else { //如果向下滚动的距离小原来导航栏离顶部的距离,则重新计算导航栏的位置 a_navigation_bar[0].style.top = (naviga_offsetTop - scrollTop) + "px"; } } //给导航条上四个tab,加上点击事件。 window.onload=function(){ var a_tabs = []; if( document.getElementsByClassName ){//Chrome, FF a_tabs = document.getElementsByClassName("tab"); }else{ //IE a_tabs = my_getElementsByClassName("tab"); } var a_contents = []; if( document.getElementsByClassName ){//Chrome, FF a_contents = document.getElementsByClassName("content"); }else{//IE a_contents = my_getElementsByClassName("content"); } //获取offsetLeft,即导航栏离左边框的距离 var a_main_p = []; if( document.getElementsByClassName ){//Chrome, FF a_main_p = document.getElementsByClassName("main"); }else{ //IE a_main_p = my_getElementsByClassName("main"); } naviga_offsetLeft = a_main_p[0].offsetLeft; a_tabs[0].onclick=function(){ window.scrollTo(0, a_contents[2].offsetTop); } a_tabs[1].onclick=function(){ window.scrollTo(0, a_contents[3].offsetTop); } a_tabs[2].onclick=function(){ window.scrollTo(0, a_contents[4].offsetTop); } a_tabs[3].onclick=function(){ window.scrollTo(0, a_contents[5].offsetTop); } //获取页面上,导航条到顶部的位置 var a_navigation_bar = []; if(document.getElementsByClassName){//Chrome, FF a_navigation_bar = document.getElementsByClassName("navigation"); } else {//IE a_navigation_bar = my_getElementsByClassName("navigation"); } //获取offsetTop naviga_offsetTop = a_navigation_bar[0].offsetTop; a_navigation_bar[0].style.left = naviga_offsetLeft + "px"; //给滚动条以及鼠标加上滚动事件 if( window.attachEvent) //IE { window.attachEvent("onmousewheel", naviga_stay_top); window.attachEvent("onscroll", naviga_stay_top); document.attachEvent("onmousewheel", naviga_stay_top); document.attachEvent("onscroll", naviga_stay_top); } else {//Chrome ,FF window.addEventListener("mousewheel", naviga_stay_top,false); window.addEventListener("scroll", naviga_stay_top,false); document.addEventListener("mousewheel", naviga_stay_top,false); document.addEventListener("scroll", naviga_stay_top,false); } }

在这个问题中,理解CSS+p定位(relative,absolute,static,fixed)的区别很重要。

relative,absolute,static,fixed

先看下各个属性值的定义:

1、static:默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。

2、relative:生成相对定位的元素,通过top,bottom,left,right的设置相对于其正常位置进行定位。可通过z-index进行层次分级。

3、absolute:生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。元素的位置通过 “left”, “top”, “right” 以及 “bottom” 属性进行规定。可通过z-index进行层次分级。

4、fixed:生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过 “left”, “top”, “right” 以及 “bottom” 属性进行规定。可通过z-index进行层次分级。

static与fixed的定位方式较好理解,在此不做分析。下面对应用的较多的relative和absolute进行分析:

1、relative。定位为relative的元素脱离正常的文本流中,但其在文本流中的位置依然存在。如图1:

图1

黄色背景的层定位为relative,红色边框区域为其在正常流中的位置。在通过top、left对其定位后,从灰色背景层的位置可以看出其正常位置依然存在。

2、absolute。定位为absolute的层脱离正常文本流,但与relative的区别是其在正常流中的位置不在存在。如图2:

图2

可以看到,在将黄色背景层定位为absolute后,灰色背景层自动补上。

3、relative与absolute的主要区别:

首先,是上面已经提到过的在正常流中的位置存在与否。

其次,relative定位的层总是相对于其最近的父元素,无论其父元素是何种定位方式。如图3:

图3

图中,红色背景层为relative定位,其直接父元素绿色背景层为默认的static定位。红色背景层的位置为相对绿色背景层top、left个20元素。而如果红色背景层定位为absolute,则情形如图4:

图4

可以看到,红色背景层依然定义top:20px;left:20px;但其相对的元素变为定位方式为absolute或relative的黄色背景层。因此,对于absolute定位的层总是相对于其最近的定义为absolute或relative的父层,而这个父层并不一定是其直接父层。如果其父层中都未定义absolute或relative,则其将相对body进行定位,如图5:

图5

除top、left、right、bottom定位外,margin属性值的定义也符合上述规则。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。