最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

基于jquery实现百度新闻导航菜单滑动动画_jquery

来源:动视网 责编:小OO 时间:2020-11-27 20:52:11
文档

基于jquery实现百度新闻导航菜单滑动动画_jquery

思路与步骤;1.利用UL创建简单横向导航。 仿百度新闻菜单滑动动画 body.div.ul.li.a { margin: 0px;padding: 0px;font-size: 20px;color: #FFF;border: 0;} .div-nav-container { margin-top: 50px;width: 100%;background-color: #01204F;} .div-nav { width: 870px;margin: 0px auto;width: 100%。
推荐度:
导读思路与步骤;1.利用UL创建简单横向导航。 仿百度新闻菜单滑动动画 body.div.ul.li.a { margin: 0px;padding: 0px;font-size: 20px;color: #FFF;border: 0;} .div-nav-container { margin-top: 50px;width: 100%;background-color: #01204F;} .div-nav { width: 870px;margin: 0px auto;width: 100%。
 本文实例为大家分享jquery实现百度新闻导航菜单滑动动画,供大家参考,具体内容如下

思路与步骤
1.利用UL创建简单横向导航;




 仿百度新闻菜单滑动动画
 


 
 
 
 
  • 网站首页
  • 热点
  • 国际新闻
  • 国内新闻
  • 国家
  • 体育新闻
  • 娱乐新闻
  • 名人
  • 古迹
  • 2.添加一个脱离层的div,命名div-hover,用于菜单滑动动画,设置CSS样式;

    
    
     
     
     
     
     ...
     
    

    3.添加菜单项的滑动事件,计算div-hover的滑动要素,左,上边距以及宽度;

    效果预览

    从预览效果可以看出,div-hover的定位是有问题的,div-hover应该以父级元素绝对定位,所以修改代码(注释部分为修改点)如下:

    
    

    虽然解决了定位问题,但是背景图片还是浮于文字上方,所以调整代码,将文字浮动于红色div之上:

    效果预览

    4.添加菜单点击,以及加载页面默认菜单选中;

    
    

    效果预览

    5.添加鼠标移出范围,自动定位当前激活元素功能;

    在做此功能之前,先理下思路,鼠标移出操作,我们可以想到mouseout,mouseleave事件,那么随之就会有以下几个疑问:

    ①这地方选用哪个事件可以满足这个条件呢?

    ②那选择的事件又定位在哪个元素呢?

    ③移出鼠标之后又如何知道当前激活的是哪个元素呢?

    ④如何知道div-hover的左边距和width等值呢?

    实践出真知,那就实践一下:

    首先,以mouseout为例,第一个问题自然就解决了;

    其次,事件定位在哪个元素?通过上面GIF图,分析,如果定位在A标签或Li标签,那么鼠标移出操作在A标签或Li标签之间切换也会触发自动定位到激活元素(假设自动定位已做),就会出现如下图所示情况:

    所以不能定位在A或Li标签上,再想一下,鼠标应该是移出整个导航的范围才可以,那么定位在哪个元素就很容易出来了,应该定位在UL或者UL的父级元素,他们两个的大小范围均是一致的,所以两个元素均可以,若两个元素大小不一致,就应该定位在UL上面了。于是就有了类似如下代码:

    然后,如何知道当前激活为何元素呢,可以在点击事件时,用隐藏域或者其他display方式存储当前点击的元素宽度和左边距,待鼠标移出操作,重新读取存储的数据,进而进行animate定位;从而解决以上③④问题;部分代码如下:

    (当然,想知道菜单激活元素,也可以用class为active的方式来查找,不过这种方式,相对来说麻烦一些,首先获得active的元素,然后通过遍历li,重新计算一遍宽度和左边距,最后进行赋值和添加滑动定位;此处暂用隐藏域方式处理,原因是方便简单,群友如有兴趣可以用active方式试验)

    效果展示:

    看图发现依旧出现之前类似定位在A或Li的问题,出现这种情况的原因:

    jquery中mouseout如果定位在一个元素上,例如div,那么此div之下的元素都会具有mouseout事件,也就是常说的,事件冒泡机制;与此类似的事件如mousedown,mouseover等,那么是不是阻止事件冒泡就行了呢? 理论上是这样的。通常阻止冒泡有两种方式: event.stopPropagation();和return false;当然他们之间也是有区别的。

    相关代码修改如下:

    无论何种阻止方式,都没有卵用,依旧阻止不了冒泡,效果可想而知,与上面Gif图所示无异;

    由此证明,mouseover在实现此功能方面是有问题的;

    那换mouseleave呢,除了将mouseover修改为mouseleave和去除冒泡代码外,其他代码不做改动,实验效果如下:

    从上图可以看出,效果与百度新闻导航滑动基本无异,至此大功告成;

    完整代码

    
    
    
     仿百度新闻菜单滑动动画
     
     
     

    总结和关键点
    1.背景滑动由某个块状元素(此处用的div)来实现,而非本元素的hover改变背景颜色;

    2.注意元素定位(滑动块状元素以谁来绝对定位或者相对定位,左边距的计算和自身宽度的计算;滑动块状元素div-hover和li之间的相对定位,以及层级大小);

    3.滑动动画事件animate和记录激活菜单,鼠标移出区域自定定位到激活菜单;

    4.jquery中mouseover,mouseout以及mouseenter,mouseleave关于冒泡机制的区别;(前两个未做冒泡机制的,后两个冒泡已经经过处理,事件只针对注册元素本身,而不会对子元素起作用,mouseenter和mouseleave用在一个元素标签上可以用hover事件代替,本身hover就是这两者的封装,如果事件在不同元素标签上,最好分开调用mouseenter和mouseleave事件)

    5.所有关键点以及作用都已经在代码各处加上注释,各位可以看看。

    希望本文对大家学习jquery程序设计有所帮助。

    文档

    基于jquery实现百度新闻导航菜单滑动动画_jquery

    思路与步骤;1.利用UL创建简单横向导航。 仿百度新闻菜单滑动动画 body.div.ul.li.a { margin: 0px;padding: 0px;font-size: 20px;color: #FFF;border: 0;} .div-nav-container { margin-top: 50px;width: 100%;background-color: #01204F;} .div-nav { width: 870px;margin: 0px auto;width: 100%。
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top