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
行文过程中出现错误或不妥之处在所难免,希望大家能够给予指正,以免误导更多人,也希望大家多多支持。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]