100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > JavaScript实现Tab点击切换实例代码分享(图文)

JavaScript实现Tab点击切换实例代码分享(图文)

时间:2022-10-21 13:21:46

相关推荐

JavaScript实现Tab点击切换实例代码分享(图文)

web前端|js教程

JavaScript,Tab,点击切换

web前端-js教程

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

九宫格导航 源码,ubuntu下载r软件,php运行python爬虫,php statment,seo修改网站lzw

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

借书app 源码,ubuntu微信双开,Tomcat文件夹打不开,衣服品牌 爬虫,php淘宝客接口开发,seo 外包终止lzw

1. 功能实现

dnf单机版源码,华为vscode插件,ubuntu更新数据存储库,访问tomcat 目录,更好控制sqlite开关,excel中倒入插件,java后台前端框架,python智能爬虫源码,韩顺平的php视频,seo软文外包公司,html网站模板源代码,网页游戏封包辅助教程,刚模板群,c winform 页面刷新,物业管理系统 源码,空包系统源码完整程序下载lzw

html部分

第一个Nian糕

第二个Nian糕

第三个Nian糕

css部分

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

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

a. 获取元素

var btnList = document.getElementsByTagName("button");var pList = document.getElementsByTagName("p");

注释: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 = ""; pList[0].style.display = "block";pList[1].style.display = "none";pList[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 = ""; pList[0].style.display = "none";pList[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"; pList[0].style.display = "none";pList[1].style.display = "none";pList[2].style.display = "block"; }

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

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

2. 优化

a. 获取元素

var btnList = document.getElementsByTagName("button");var pList = document.getElementsByTagName("p");

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 = ""; pList[j].style.display = "none"; } //给点击的按钮添加样式,对应的块显示 this.style.color = "#fff"; this.style.backgroundColor = "#f60"; pList[this.index].style.display = "block"; }}

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

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

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

3. Let 命令

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

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

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

a. 获取元素

var btnList = document.getElementsByTagName("button");var pList = document.getElementsByTagName("p");

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=""; pLists[j].style.display="none"; } this.style.color = "yellow"; this.style.backgroundColor="#f60"; pLists[i].style.display="block"; }}

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

End of File

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。