用js和css实现选项卡效果+jq(2019-10-09)
2024-09-01 16:27:29
1效果图:
2代码:
html:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>选项卡效果</title>
<link rel="stylesheet" href="../css/tab-list.css">
</head>
<body>
<div class="main">
<ul id="option">
<li onclick="setTab(0)">第一张</li>
<li onclick="setTab(1)">第二张</li>
<li class="active" onclick="setTab(2)">第三张</li>
<li onclick="setTab(3)">第四张</li>
</ul>
<ul id="content">
<li>第一张内容</li>
<li>第二张内容</li>
<li class="active">第三张内容</li>
<li>第四张内容</li>
</ul>
</div>
<script src="../js/tab-list.js"></script>
</body>
</html>
css:
*{
padding:;
margin:;
list-style:none;
}
.main{
width:100%;
margin-top:50px;
}
#option{
height:38px;
line-height:38px;
border:1px solid darkgray;
width:396px;
margin: 0 auto;
border-radius:5px 5px 0 0;
}
#option li{
float:left;
height:38px;
width:99px;
text-align: center;
background-color:darkkhaki;
border-right:1px solid dargray;
cursor: pointer;
}
#option li.active{
background-color:blue;
}
#content{
border:1px solid darkgray;
border-top:none;
width:396px;
margin: 0 auto;
border-radius:0 0 5px 5px;
}
#content li{
display:none;
height:200px;
line-height:200px;
text-align: center;
}
#content li.active{
display:block;
}
js:
var options = document.getElementById("option").getElementsByTagName("li");
var contents = document.getElementById("content").getElementsByTagName("li");
function setTab(n){
for(let i=0;i<options.length;i++){
if(i==n){
options[i].className="active";
contents[i].style.display="block";
}else{
options[i].className="";
contents[i].style.display="none";
}
}
}
3总结:
总的来说,还是用js选中点击的元素,在修改css样式。
学习到的css属性:
1:border-radius:圆角
border-radius:5px;对四个角设置圆角属性
border-radius:5px 0;对左上和右下角设置圆角属性
border-radius:0 0 5px 5px;对右下角和左下角设置圆角属性
四个值: 第一个值为左上角,第二个值为右上角,第三个值为右下角,第四个值为左下角(顺时针顺序)。
2:cursor: 鼠标移动在选定元素上的样式
cursor:pointer;一只手
cursor:wait;转圈圈
cursor:text;文本
3:display:none;隐藏元素,同时被隐藏的元素不影响页面上的其他元素。
4 补充(2019-10-09),jq实现
html:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>选项卡效果</title>
<link rel="stylesheet" href="../css/tab-list.css">
<script src="../js/lib/jquery-3.2.1.min.js"></script>
</head>
<body>
<div class="main">
<ul id="option">
<li class="active">第一张</li>
<li>第二张</li>
<li>第三张</li>
<li>第四张</li>
</ul>
<ul id="content">
<li class="active">第一张内容</li>
<li>第二张内容</li>
<li>第三张内容</li>
<li>第四张内容</li>
</ul>
</div>
<script src="../js/tab-list.js"></script>
</body>
</html>
js:
$("ul#option li").click(function(){
$(this).addClass("active").siblings().removeClass("active");
var index = $(this).index();
$("ul#content li").eq(index).addClass("active").siblings().removeClass("active");
})
总结:
1先选取要触发的区域
2获取点击的dom节点并获取index位置
3对应内容的index的dom节点修改
最新文章
- ionic之$ionicGesture手势(大坑)
- Ubuntu Server无线连接配置
- 微信中一些常用的js事件积累
- Network - DNS
- ZYB&#39;s Premutation POJ5592
- 解决Windows 10下Wireshark运行问题
- EasyUI基础入门之Parser(解析器)
- Block之变量作用域
- bzoj1311: 最优压缩
- Qt 学习之路 :自定义只读模型
- h5 localStorage存储大小(转)
- LSA和pLSA的比较
- tp3.2 事务处理
- Apache Traffic Server服务搭建
- C# 查看EF生成的SQL语句
- pytorch识别CIFAR10:训练ResNet-34(准确率80%)
- linux 下vim中关于删除某段,某行,或者全部删除的命令 ZZ
- Setting
- STM32串口usart发送数据
- 最近github上的一些有用链接资料备份
热门文章
- 50个实用的jq代码段整理
- sech和asech--双曲正割和反双曲正割函数
- Java自动化测试框架-02 - TestNG之理论实践 - 纸上得来终觉浅,绝知此事要躬行(详细教程)
- .netCore+Vue 搭建的简捷开发框架--目录
- wamp server mysql数据库中事件不执行的解决办法
- 爬虫破解知乎登入(不使用Selenium模块)
- 实验吧之【who are you?】(时间盲注)补充
- 【websocket】spring boot 集成 websocket 的四种方式
- java集合之Vector向量基础
- php好在哪?