位置: 编程技术 - 正文

分步解析JavaScript实现tab选项卡自动切换功能(java分布式计算)

编辑:rootadmin

推荐整理分享分步解析JavaScript实现tab选项卡自动切换功能(java分布式计算),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:java分布式解决方案,分步解析法,java分布式教程,java分布式教程,分步解析空心麻饼的两种实用做法,分步解析法,java分布式教程,内部交易存货抵消分录分步解析,内容如对您有帮助,希望把文章链接给更多的朋友!

本文分享一个能够实现自动切换的选项卡功能,并给出它的具体实现过程。

关于选项卡大家一定不会陌生,应用非常的频繁,通常选项卡都是需要点击或者划过才能够实现切换。代码实例如下:

上面的代码实现了我们的要求,下面介绍一下它的实现过程。(1)模拟实现jQuery中的id选择器,参数是元素的id属性值

function $(id){return typeof id === "string" &#; document.getElementById(id) : id;}

(2).function $$(oParent, elem){ return (oParent || document).getElementsByTagName(elem);},此函数实现了后去指定元素下所有特定元素的对象集合。(3).此函数的功能是将oParent元素下所有class属性值为sClass的元素存入数组

(4)事件处理函数的绑定封装,实现了浏览器兼容功能。

(5).此方法实现了基本的初始化操作

分步解析JavaScript实现tab选项卡自动切换功能(java分布式计算)

(6).实现了合并对象的功能,比如可以将对象a中的属性合并到对象b中

(7).Tab.prototype = {},设置Tab构造函数的原型对象。(8).initialize : function(obj, dis, content, onEnd, eq){},此方法可以进行一些初始化操作。第一个参数是元素id属性值,第二个参数是class样式类,第三个参数是内容div的class样式类名称,第四个参数是一个对象直接量,里面存储了一些相关参数,第五个参数规定默认哪个选项卡被选中,是一个数字。(9).this.obj = $(obj),获取指定的元素对象。().this.oList = $$$(this.obj, 'list')[0],获取class属性值为list的标题外层div元素。().this.aCont = $$$(this.obj, content),获取选项卡内容元素集合。().this.oUl = $$(this.oList, 'ul')[0],获取标题ul元素。().this.aLi = this.oUl.children,获取ul元素下的所有子元素。().this.timer = null,用作定时器函数的标识。().eq &#; (this.aLi.length < eq &#; eq = 0 : eq) : eq = 0,如果eq是0则使用0,否则的话将使用eq传递的值,eq值要小于数组长度,否则eq值设置为0。().this.oEve(onEnd),覆盖默认设置。().this.onEnd.method == 'mouseover' &#; this.method = "mouseover" : this.method = "click",判断是mouseover事件还是click事件。().this.onEnd.autoplay == 'stop' &#; this.autoplay = "stop" : this.autoplay = "play",默认是自动播放,否则就不是自动播放。().this.aCont[eq].style.display = 'block',默认内容项显示。().this.aLi[eq].className = 'hove',设置对应的标题选项卡样式。().this.display(dis),注册事件处理函数,参数是一个样式类名称。().this.autoPlayTab(eq, dis),执行此函数确保在允许自动切换的时候选项卡可以自动切换。().

用来进行对象合并

这是默认的设置

如果传递了onend对象,就将其合并到默认对象,否则合并一个空对象

().display : function(dis){},注册事件处理函数,参数是一个样式类名称。().var _this = this,将this赋值给变量_this,为什么这么做后面会介绍。().var index = iNow = 0,进行一些初始化操作。().for(index=0;index<_this.aLi.length;index++){},通过for循环遍历的方式注册事件处理函数。()

使用匿名自执行函数,其实就是形成了一个闭包。之所以用闭包,是为了隔离匿名函数内部的index值和外部的index值。之所以将this赋值给_this是因为,事件处理函数中的this是指向元素li的,而不是指向Tab()构造函数的对象实例。().autoPlayTab : function(iNow, dis){},此函数实现了自动切换功能,第一个参数规定当前选项卡切换所处的索引位置,第二个参数一个样式类名称,就是设置处于当前状态的样式。().if(this.autoplay == 'play'){},判断是否允许自动切换。().var _this = this,将this赋值给变量_this,原理和上面是一样的。().this.iNow = iNow,进行赋值操作。().this.obj.onmouseover = function(){ clearInterval(_this.timer);},当鼠标悬浮的时候的时候停止定时器函数的执行,其实也就是停止自动切换。

().当鼠标离开的时候,开始自动切换动作

().clearInterval(_this.timer),停止以前的定时器函数执行。()._this.timer = setInterval(playTab,),开始自动切换。().

不断调用此函数就实现了自动切换功能。如果当前的索引等于li元素的个数,那么就将其设置为0,也就是从头进行新一轮切换。然后调用对应的方法,并且让索引值自增。

()实现了选项卡的切换显示隐藏和样式设置效果

标签: java分布式计算

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

上一篇:JavaScript、jQuery与Ajax的关系

下一篇:JavaScript数据类型学习笔记(javascript数据类型有哪些)

  • 营业外收入交企业所得税可以扣除成本么
  • 社保公积金占比多少
  • 企业账号变更
  • 发票代签怎么处理
  • 进口增值税可以抵税吗
  • 成品油购进数据未同步怎么办
  • 无形资产有合同约定,怎么摊销?
  • 在建工程转固定资产需要什么附件
  • 个体工商户转让流程
  • 企业可以不弥补以前年度亏损吗
  • 提取法定盈余公积会计分录
  • 垫资后转出的会计分录怎么写?
  • 实收资本属于会计科目吗
  • 营改增对资产负债表的影响
  • 月工资和账户工资区别
  • 报完税后反结账调整主营业务收入可以吗?
  • 福利费开专票怎么处理
  • 补充养老保险计算器
  • 固定资产原值减预计净残值等于什么
  • 哪些税金计入存货成本
  • 长期待摊费用期末在借方还是贷方
  • 从银行提取备用金填制什么凭证
  • 收取违约金如何入账
  • win10怎么清理剪切板
  • phpstudy配置ftp服务器
  • 本年利润和未分配利润怎么结转
  • Http请求-hutool工具类的使用
  • PHP:json_last_error()的用法_JSON函数
  • 约书亚树国家公园
  • vue笔记项目
  • 行政单位基建账如何并入大账
  • 深度学习大模型框架的简单介绍(ChatGPT背后原理的基本介绍)
  • vue computed set get
  • 资产负债表和利润表的勾稽关系
  • 其他应收款的会计分录有哪些
  • Simple Slug Translate 把WordPress固定链接自动翻译成英文
  • 织梦面包屑导航最后的分隔符大于号去掉方法
  • 交通费中的高速费指什么
  • 金融商品转让和贷款服务
  • 餐饮个体户如何申请开票
  • 资源税类的税种是
  • 会计政策变更追溯调整的年限
  • 材料采购的账务怎么处理
  • 民办非企业单位工会经费
  • 外资企业可以融资吗
  • 期末留抵税额和账上哪一个数对应
  • 收到员工社保
  • 付当月房租怎么做分录
  • 如何发放银行贷款利息
  • 年底本年利润结转错了怎么调
  • 一般纳税人房租租赁费的税率
  • 货物赔偿款计入什么会计科目
  • 政府补助收入是指县级以上工会收到的
  • 初级会计现值的计算
  • mysql建索引有哪些策略和原则
  • MYSQL数据库原理及应用
  • mysql5717安装及配置超详细教程
  • win7显示无线网络未连接
  • win8.1还原系统
  • 安装win8一直卡在转圈圈
  • windows 2003 iis+php5+mysql+phpmyadmin 详细安装配置
  • brasil.exe是什么进程
  • windows2.0下载
  • win8如何添加启动项
  • xp系统本地连接启用不了
  • mac重装macos
  • 笔记本摄像头摄像
  • mac和iphone互动
  • linux文件系统损坏导致网络断开
  • win7如何格式化D盘
  • Win7旗舰版系统镜像文件
  • cocos2dx入门
  • 利用python进行
  • 五个常用的视频格式及其特点
  • javascript概述
  • jQuery Ajax 加载数据时异步显示加载动画
  • Activity与Theme
  • jquery中的attr方法
  • 湖北国税发票真伪查询
  • 广东省地方税务局班子成员
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设