全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript 实现 Tab 点击切换实例代码

Tab 选项卡切换效果在现如今的网页中,运用的也是比较多的,包括点击切换、滑动切换、延迟切换、自动切换等多种效果,在这篇博文里,我们是通过原生 JavaScript 来实现 Tab 点击切换的效果

1. 功能实现

html 部分

<button style="background-color:#f60; color: #fff;">按钮1</button>
<button>按钮2</button>
<button>按钮3</button>
<div style="display:block;">第一个Nian糕</div>
<div>第二个Nian糕</div>
<div>第三个Nian糕</div>

css 部分

div {
 display: none;
 width: 155px;
 height: 100px;
 border: 1px solid #000;
}

接下来是 JS 部分,根据每一步要实现的功能,进而转换成代码,每当我们要实现一个效果的时候,先不要急着去敲代码,而是先思考要怎么去实现,结构是什么样的,某个功能需要用到什么事件等等,自己在脑海里把整个流程过一遍,再去把每一步的逻辑转换成代码

a. 获取元素

var btnList = document.getElementsByTagName("button");
var divList = document.getElementsByTagName("div");

注释: document.getElementsByTagName 返回的是一个[类数组对象],可以使用数组的方法对其进行处理,但类数组对象并不具有数组所具有的方法

b. 给元素绑定点击事件

//第一个按钮的点击事件
btnList[0].onclick = function () {
 btnList[0].style.color = "#fff";
 btnList[0].style.backgroundColor = "#f60";
 btnList[1].style.color = "";
 btnList[1].style.backgroundColor = "";
 btnList[2].style.color = "";
 btnList[2].style.backgroundColor = "";
 divList[0].style.display = "block";    
 divList[1].style.display = "none";    
 divList[2].style.display = "none";    
}
//第二个按钮的点击事件
btnList[1].onclick = function () {
 btnList[0].style.color = "";
 btnList[0].style.backgroundColor = "";
 btnList[1].style.color = "#fff";
 btnList[1].style.backgroundColor = "#f60";
 btnList[2].style.color = "";
 btnList[2].style.backgroundColor = "";  
 divList[0].style.display = "none";    
 divList[1].style.display = "block";    
}
//第三个按钮的点击事件
btnList[2].onclick = function () {
 btnList[0].style.color = "";
 btnList[0].style.backgroundColor = "";
 btnList[1].style.color = "";
 btnList[1].style.backgroundColor = "";
 btnList[2].style.color = "#fff";
 btnList[2].style.backgroundColor = "#f60";
 divList[0].style.display = "none";    
 divList[1].style.display = "none";    
 divList[2].style.display = "block";  
}

现在我们已经实现了一个 Tab 切换的效果了,来看一下效果


虽然很简陋,但已经达到我们想要的效果了,读者可根据自己想要的样式来设置 CSS,接下来我们要做的就是,对 JS 代码进行优化

2. 优化

a. 获取元素

var btnList = document.getElementsByTagName("button");
var divList = document.getElementsByTagName("div");

b. 给每一个 button 元素绑定点击事件

for(var i = 0; i < btnList.length; i++ ) {
 btnList[i].index = i; //给每个按钮添加index属性,标记是第几个按钮
 btnList[i].onclick = function() {
  for(var j = 0; j < btnList.length; j++) {
   //将所有的按钮样式去掉,块隐藏
   btnList[j].style.color = "";
   btnList[j].style.backgroundColor = "";
   divList[j].style.display = "none";
  }
  //给点击的按钮添加样式,对应的块显示
  this.style.color = "#fff";
  this.style.backgroundColor = "#f60";
  divList[this.index].style.display = "block";
 }
}

index 返回字符位置,它是被搜索字符串中第一个成功匹配的开始位置,从零开始

this 是 Javascript 的一个关键字,它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用 this,关于 this 的值,会跟随函数使用场景的不同而发生变化,但是我们只需要记住一个原则就可以了,this 指的是调用函数的那个对象

在这里 this 指向对应的点击按钮,我们可以通过控制台打印来看到 this 所输出的内容


3. Let 命令

ES 6 中新增了 let 命令,用来声明变量,其用法类似于 var,但是所声明的变量,只在 let 命令所在的代码块内有效


在上面的代码中,我们在代码块里,分别用 var let 声明了两个变量,接着在代码块内外打印这两个变量,可以看到,var 声明的变量返回了正确的值,代码块内打印 let 声明的变量返回了正确的值,而在代码块外打印 let 声明的变量报错,这表明,let 声明的变量只在它所在的代码块有效


上面代码中,变量 i var 声明的,在全局范围内都有效,所以全局只有一个变量 i,每一次循环,变量 i 的值都会发生改变,而循环内被赋给数组 a function 在运行时,会通过闭包读到这同一个变量 i,导致最后输出的是最后一轮的 i 的值,也就是 10,而如果使用 let,声明的变量仅在块级作用域内有效,最后输出的是 6

a. 获取元素

var btnList = document.getElementsByTagName("button");
var divList = document.getElementsByTagName("div");

b. 给每一个 button 元素绑定点击事件

for(let i = 0; i < btnLists.length; i++) {
 btnLists[i].onclick = function() {
  for(var j = 0;j < btnLists.length;j++){
   btnLists[j].style.color="";
   btnLists[j].style.backgroundColor="";
   divLists[j].style.display="none";
  }
  this.style.color = "yellow";
  this.style.backgroundColor="#f60";
  divLists[i].style.display="block";
 }
}

同样的,我们也是控制台来打印一下 i 的值


End of File

行文过程中出现错误或不妥之处在所难免,希望大家能够给予指正,以免误导更多人,也希望大家多多支持。


# javascript  # tab切换  # js实现tab选项卡切换  # js点击切换tab  # JavaScript实现的简单Tab点击切换功能示例  # JS实现淡蓝色简洁竖向Tab点击切换效果  # 简单纯js实现点击切换TAB标签实例  # js实现点击切换TAB标签实例  # Vue.js点击切换按钮改变内容的实例讲解  # JS实现的简单标签点击切换功能示例  # 原生JS实现隐藏显示图片 JS实现点击切换图片效果  # JavaScript实现点击切换功能  # JavaScript实现多个重叠层点击切换效果的方法  # JavaScript实现Tab点击切换  # 的是  # 第一个  # 绑定  # 第二个  # 只在  # 第三个  # 转换成  # 几个  # 在这里  # 之处  # 只需  # 而在  # 它是  # 一遍  # 我们可以  # 这两个  # 对其  # 要做  # 现如今  # 可以看到 


相关文章: C#如何序列化对象为XML XmlSerializer用法  如何在IIS中新建站点并解决端口绑定冲突?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何快速搭建支持数据库操作的智能建站平台?  建站主机无法访问?如何排查域名与服务器问题  ppt制作免费网站有哪些,ppt模板免费下载网站?  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  清除minerd进程的简单方法  商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?  建站之星代理商如何保障技术支持与售后服务?  如何在Ubuntu系统下快速搭建WordPress个人网站?  建站之星云端配置指南:模板选择与SEO优化一键生成  建站之星免费模板:自助建站系统与智能响应式一键生成  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  如何用搬瓦工VPS快速搭建个人网站?  广州商城建站系统开发成本与周期如何控制?  新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  如何快速查询网站的真实建站时间?  如何在阿里云虚拟主机上快速搭建个人网站?  如何在云虚拟主机上快速搭建个人网站?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  自助网站制作软件,个人如何自助建网站?  广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  建站VPS选购需注意哪些关键参数?  建站VPS推荐:2025年高性能服务器配置指南  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?  小型网站制作HTML,*游戏网站怎么搭建?  在线制作视频的网站有哪些,电脑如何制作视频短片?  如何在阿里云购买域名并搭建网站?  如何在IIS中新建站点并配置端口与物理路径?  建站之星如何取消后台验证码生成?  建站org新手必看:2024最新搭建流程与模板选择技巧  英语简历制作免费网站推荐,如何将简历翻译成英文?  c# 在高并发下使用反射发射(Reflection.Emit)的性能  网站制作话术技巧,网站推广做的好怎么话术?  常州企业网站制作公司,全国继续教育网怎么登录?  做企业网站制作流程,企业网站制作基本流程有哪些?  三星网站视频制作教程下载,三星w23网页如何全屏?  建站主机是否等同于虚拟主机?  如何用美橙互联一键搭建多站合一网站?  制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?  如何撰写建站申请书?关键要点有哪些?  Swift中swift中的switch 语句  建站之星2.7模板:企业网站建设与h5定制设计专题  小程序网站制作需要准备什么资料,如何制作小程序?  已有域名如何快速搭建专属网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。