位置: 编程技术 - 正文

基于jquery实现百度新闻导航菜单滑动动画(如何用jquery)

编辑:rootadmin

推荐整理分享基于jquery实现百度新闻导航菜单滑动动画(如何用jquery),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:使用jquery,jquery教程 csdn,jquery100例,使用jquery实现的项目,使用jquery实现的项目,jquery100例,jquery的实现原理,jquery100例,内容如对您有帮助,希望把文章链接给更多的朋友!

本文实例为大家分享jquery实现百度新闻导航菜单滑动动画,供大家参考,具体内容如下

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

2.添加一个脱离层的div,命名div-hover,用于菜单滑动动画,设置CSS样式;

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

效果预览

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

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

效果预览

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

效果预览

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

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

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

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

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

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

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

基于jquery实现百度新闻导航菜单滑动动画(如何用jquery)

首先,以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是否加载在使用jQuery进行任何操作之前,你需要先确认它已经加载:if(typeofjQuery=='undefined'){console.log('jQueryhasn'tloaded');}else{console.log('jQueryhasloade

基于jQuery Tipso插件实现消息提示框特效 基于jQueryTipso插件实现消息提示框的特点是可以定义提示框的显示位置,以及动态改变提示框的提示内容,应该说是一款相当灵活的jQuery消息提示框插件

jQuery实现放大镜效果实例代码 在没给大家做详细文字说明之前,先给大家分享一段简单的jquery实现放大镜效果代码,需要的朋友可以直接拿去代码。$(function(){varmouseX=0;//鼠标移动的

标签: 如何用jquery

本文链接地址:https://www.jiuchutong.com/biancheng/384006.html 转载请保留说明!

上一篇:一步步教大家编写酷炫的导航栏js+css实现(怎样编?)

下一篇:Jquery技巧(必须掌握)(不用jquery用什么)

  • 公司购买二手房可以开增值税专用发票吗
  • 小规模纳税人场地租赁
  • 利润表中所得税费用包括哪些
  • 房地产增值税怎么算抵扣土地款
  • 发票能加盖公章吗
  • 如何区分劳务报酬与经营所得
  • 机器设备折旧计提规定
  • 在建工程待摊支出例题
  • 确定发出存货实际成本的方法
  • 哪些发票可以报销抵税
  • 餐饮店进货要索取哪些单据
  • 生产企业研发用原料抵进项可以吗?
  • 销售货物运费的增值税率
  • 一般纳税人印花税减半征收吗
  • 购买的无形资产入账价值
  • 苹果电脑如何缩小图片大小
  • 老毛桃u盘启动盘制作工具怎么安装win10系统 老毛桃u盘安装win10系统图文教程
  • linux sed命令详解
  • 完税证明和纳税申报表是一种东西吗
  • win7上网提速
  • php pdo分页
  • 暂估入库结转成本后期怎么冲账
  • 向国外个人支付的佣金是否缴纳个人所得税
  • 工程结算需要哪些施工方案
  • 增值税一般纳税人资格登记表
  • 广电默认网关是多少
  • php7 数组
  • 新公司30天内未办理税务登记
  • 精灵烟囱的形态判断
  • 公司员工个人所得税交多少
  • 会计期初余额和期末余额计算公式
  • php进行批量任务分类
  • uniapp新建项目
  • 消费税会计分录怎么做的
  • yolov3实例
  • 微信小程序在哪里打开
  • Vue3-Pinia的基本使用
  • php windows
  • 自产产品对外赠送的会计处理方法
  • 什么情况下应该辞职
  • 建筑公司包含哪些业务
  • 小规模开劳务费可以开多少
  • file file=new file()的作用
  • 销售费用工资是什么科目
  • 电子发票报销需要签字吗
  • 工程咨询服务发展的指导意见有哪些
  • 建筑工程分包案例
  • 工商营业执照年检网上怎么年检
  • sqlserver聚集函数
  • 招待客户的交通费可以算招待费吗
  • 税控盘的进项税在哪里申报
  • 现金流量表的编制依据
  • 职工福利费无发放原因
  • 所得税审核一般需要多久
  • 报销车辆通行费怎么做账
  • 解缴税费
  • 直接费用的定义
  • 社区养老服务平台
  • 日记账的设置和登记
  • Win10系统怎么进入控制面板
  • bash是什么意思中文翻译
  • mac快捷键使用
  • win8双桌面
  • a4腰多大
  • win8 cmd在哪
  • 查看linux的命令
  • linux解密
  • c#开发linux
  • dev c++怎么配置环境
  • bat批处理执行cmd命令
  • java多线程产生死锁
  • jqueryif判断
  • python简单编码
  • android系统内核基于什么操作系统?
  • 云南省税务局app缴费
  • 如何在同一台电脑上投屏
  • 智利有什么自然景观
  • 证券经纪人收入构成
  • 地税审计税务稽查局职责
  • 一般纳税人申请流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设