博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用JQuery实现手风琴布局
阅读量:5332 次
发布时间:2019-06-14

本文共 2094 字,大约阅读时间需要 6 分钟。

当鼠标在元素上悬停或移出时,可以通过JQuery的hover方法来给元素绑定两个处理方法,前者用于鼠标悬停,后者用于鼠标移出,因此根据这这特点再设置相应元素的css属性后就可以方便的实现手风琴布局,然而这样的却有个问题,即当鼠标移出时就导致内容被隐藏,示例代码如下:
<html>
<head>
<title>Demo</title>
<script language="javascript" type="text/javascript" src="jquery-2.1.3.js"></script>
<style>
.title
{
width:300px;
height:25px;
line-height:25px;
text-align:left;
vertical-align:center;
border:1px solid blue;
 
}
 
.content
{
width:300px;
height:100px;
display:none;
border:1px solid blue;
}
</style>
<script type="text/javascript">
$(function(){
$(".title").hover(function(){
$(this).next().css("display", "block");
}, function(){
$(this).next().css("display", "none");
});
})
</script>
</head>
<body>
<div class="title">
title1
</div>
<div class="content">
content1
</div>
<div class="title">
title2
</div>
<div class="content">
content2
</div>
<div class="title">
title3
</div>
<div class="content">
content3
</div>
<div class="title">
title4
</div>
<div class="content">
content4
</div>
</body>
</html>
 
鉴于使用hover实现手风琴布局的缺点,可以用另一种方式来实现更好的效果,即先定义一个select类样式,有该类样式的div的display属性为block,然后使用JQuery给发生click事件的title绑定事件处理方法,在改方法中首先移去select类,再给该titile的content添加select样式,代码如下:
<html>
<head>
<title>Demo</title>
<script language="javascript" type="text/javascript" src="jquery-2.1.3.js"></script>
<style>
.title
{
width:300px;
height:25px;
line-height:25px;
text-align:left;
vertical-align:center;
border:1px solid blue;
 
}
 
.content
{
width:300px;
height:100px;
display:none;
border:1px solid blue;
}
 
.display
{
display:block;
}
</style>
<script type="text/javascript">
$(function(){
$(".title").click(function(){
$(".content").removeClass("display");
$(this).next().addClass("display");
})
})
</script>
</head>
<body>
<div class="title">
title1
</div>
<div class="content">
content1
</div>
<div class="title">
title2
</div>
<div class="content">
content2
</div>
<div class="title">
title3
</div>
<div class="content">
content3
</div>
<div class="title">
title4
</div>
<div class="content">
content4
</div>
</body>
</html>
第二种方式完美的实现了手风琴布局,当然也可以不使用添加类样式的方式,而通过JQuery的hide和show方法来完成同样的功能。

转载于:https://www.cnblogs.com/lvniao/p/4638719.html

你可能感兴趣的文章
rsync配置和同步数据
查看>>
uva11630 or hdu2987 Cyclic antimonotonic permutations(构造水题)
查看>>
UIButton的resizableImageWithCapInsets使用解析
查看>>
[翻译] SCRecorder
查看>>
DDCTF2019 的四道题wp
查看>>
linux maven安装(三)
查看>>
Unity3D笔记十三 摄像机之间切换
查看>>
.eww
查看>>
MUI框架-01-介绍-创建项目-简单页面
查看>>
过滤数据
查看>>
Codeforces 992 范围内GCD,LCM要求找一对数 衣柜裙子期望
查看>>
ssh The authenticity of host '10.11.26.2 (10.11.26.2)' can't be established
查看>>
代码学习总结
查看>>
初入Installshield2015
查看>>
003 centos7中关闭防火墙
查看>>
仪表盘
查看>>
AutoCloseable的用法
查看>>
eclipse工程重命名后,无法生产class问题
查看>>
第十章 call和ret指令
查看>>
关于字典序的若干问题
查看>>