比较复杂的用户界面,tab面板 伸缩面板和折叠面板等组件。

tab面板和菜单实际上分为两种
一种是切换各个tab页中的内容时并不刷新浏览器窗口,仅仅是被隐藏起来了 利用javascript显示和隐藏tab面板
另一种是切换各个tab页中的内容时,会刷新浏览器窗口,实际上就是更换了一个新的html页面 也可以局部刷新tab页面内的区域,利用ajax技术。
浏览器无刷新的制作效果为tab面板,因为他是一个页面中的一个区域
浏览器刷新的制作效果为tab菜单,因为它是多个页面之间的导航菜单
一.tab菜单
浏览器刷新 即载入不同的页面
1. 搭建html结构
为每个页面都设置相同的框架
<body id="home">
<ul id="tabnav">
<li class="home"><a href="home.htm">home</a></li>
<li class="dev"><a href="dev.htm">dev</a></li>
<li class="design"><a href="design.htm">design</a></li>
</ul>
<ul>
<div id="content">
<ul id="list">
<li>1.asdfasdf</li>
<li>2.asdfgasdfasdf</li>
<li>3.asdfaasdghhhjjkkksdf</li>
</ul>
</div>
</body>
除了每个页面的具体内容,即上面代码中div中包含的部分外,所有tab页面的整体框架都是完全相同的,每个页面都采用<link>语句调用相同的css外部文件,而页面的具体内容所采用的css则放在页面内用<style>标记控制,代码如下
<link href="tab.css" type="text/css" rel="stylesheet">
2.设置整体样式
外部的tab。css文件中定义各个css属性:
body{margin:10px;}
#content{
border-left:1px solid #lla3ff;
border-right:1px solid #lla3ff;
border-bottom:1px solid #lla3ff;
padding:5px;
font-size:12px;
}
3.设置tab的样式
ul #tabnav{
list-style-type:none;
margin:0px;
padding-left:0px;
padding-bottom:23px;
border-bottom:1px solid #11a3ff;
font:bold 12px verdanna,arial;
}
再设置li的样式
ul#tabnav li{
float:left;
height:20px;
margin:0 3 0 0;
border:1 solid #11a3ff;
}

设置所有超链接的3个伪类,
ul#tabnav a:link,ul#tabnav a:visited{
display:block;
color:#006eb3;
text-decoration:none;
padding:5 10 3 10;
}
ul#tabnav a:hover{
color:#ffffff;
}
设置当前页的tab样式
每个页面的body标记都添加唯一的id,因此可以设置当前页面的菜单项,如home.htm的home菜单等,
给当前页的菜单项添加白色的下边框,从而覆盖了ul标记中设置的蓝色下边框,实现了tab菜单的效果,此时效果如下所示
body#home li.home,body#dev li.dev,body#design li.design...{
border-bottom:1px solid #ffffff;
color:#000000;
}
tab菜单和核心部分已经完成,下面为当前页面的菜单项添加单独的超链接效果,以区别于其他页面,代码如下
body#home li.home a:link,body#home li.home a:visited,body#home li.dev a:visited,......{
color:#000000;
}
body#home li.home a:hover,body#dev li.dev a:hover...
{
color:#006eb3;
text-decoration:underline;
}
为每个页面添加相应的内容,内容部分使用css于公共的css样式文件分别存放,可以使用style嵌入到页面中
代码如下:
<link href="tab.css" type="text/css" rel="stylesheet">
<style type="text/css">
放置各个页面单独的具体内容所使用的css
</style>
二,借助于spry实现tab面板
1html结构
<body>
<div id="tp1" class="tps">
<ul class="tpg">
<li class="tt" tabindex="0"><span>t1</span></li>
<li class="tt" tabindex="0"><span>t2</span></li>
</ul>
</div>
<div class="tpcontentg">
<div class="tpc">内容1</div>
<div class="tpc">内容2</div>
</div>
</body>
2,背景图片

3.设置整体的css样式
.tps{
margin:0;
padding:0;
float:left;
clear:none;
width:100%;
.tpg{
margin:0;
padding:0;
}
4.设置单个tab的css的样式
.tt{
display:block;
height:30px;
float:left;
position:relative;
top:2;
padding:0 0 0 0;
margin:0 0 0 0;
background:url('tab-back.gif');
list-style:none;
cursor:pointer;
color:#fff;
font:bold 14 arial;
-moz-user-select:none;
-khtml-user-select:none;
}
5.设置单个tab的滑动门背景
要利用html中span标签作为钩子来载入右边的背景图
将tt设置为padding:0 0 0 15;
对span增加css设置
.tt span{
display:block;
background:url('tab-back.gif') right top;
padding:7 25 7 0;}
6.设置鼠标经过效果
.tthover{
}
更改为:
.tthover span{
display:block;
background:url('tab-hover.gif') right top;
padding:7 25 7 0;
}

7.设置当前页效果
.ttselected{
border-bottom:1px solid #eee;
}
替换为
.ttselected{
background:url('tab-current.gif');
color:#900;
}
.ttsecected span{
display:block;
background:url('tab-current.gif') right top;
padding:7 25 7 0;
}
8.设置tab页内容的css样式
.tpcontentg{
clear:both;//清除浮动的影响
border:solid 2 #900;
}
9.鼠标经过时换页
在html代码中加入如下语句
<div id="tp1" class="tp">
<ul class="tpg">
<li class="tpt tabindex="0" onmouseover="tp1.showpanel(0)"><span>home</span></li>
<li class="tpt tabindex="0" onmouseover="tp1.showpanel(1)"><span>web development</span></li>
</ul>
</div>
增加onmouserover事件处理语句 当鼠标指针经过时就会显示该tab页
三。折叠面板
效果如下图
1.简历基本的折叠面板
2.准备背景图片

- mysql 12章_MySQL数据库的高级管理
一. 用户管理 Root用户是MySQL数据库管理系统中的系统管理员,但在实际开发过程中通常需要根据不同的开发者分配不同的用户,这样有利于用户的管理和维护. . 用户的创建: ) 方式1:使用MySQ ...
- CSS3秘笈第三版涵盖HTML5学习笔记9~12章
第9章,装饰网站导航 限制访问,处于隐私方面考虑,浏览器已经开始限制可以对伪类:visited应用哪些CSS属性了.其中包括对已访问过的链接定义color.background-color.borde ...
- 20191105 《Spring5高级编程》笔记-第12章
第12章 使用Spring远程处理 12.4 在Spring中使用JMS 使用面向消息的中间件(通常成为MQ服务器)是另一种支持应用程序间通信的流行方法.消息队列(MQ)服务器的主要优点在于为应用程序 ...
- javascript高级程序设计第3版——第12章 DOM2与DOM3
12章——DOM2与DOM3 为了增强D0M1,DOM级规范定义了一些模块. DOM2核心:为不同的DOM类型引入了一些与XML命名空间有关的方法,还定义了以编程方式创建Document实例的方法: ...
- Linux就这个范儿 第12章 一个网络一个世界
Linux就这个范儿 第12章 一个网络一个世界 与Linux有缘相识还得从一项开发任务说起.十八年前,我在Nucleus OS上开发无线网桥AP,需要加入STP生成树协议(SpanningTree ...
- Hadoop专业解决方案-第12章 为Hadoop应用构建企业级的安全解决方案
一.前言: 非常感谢Hadoop专业解决方案群:313702010,兄弟们的大力支持,在此说一声辛苦了,春节期间,项目进度有所延迟,不过元宵节以后大家已经步入正轨, 目前第12章 为Hadoop应用构 ...
- 《Entity Framework 6 Recipes》中文翻译系列 (30) ------ 第六章 继承与建模高级应用之多对多关联
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 第六章 继承与建模高级应用 现在,你应该对实体框架中基本的建模有了一定的了解,本章 ...
- 敏捷软件开发:原则、模式与实践——第12章 ISP:接口隔离原则
第12章 ISP:接口隔离原则 不应该强迫客户程序依赖并未使用的方法. 这个原则用来处理“胖”接口所存在的缺点.如果类的接口不是内敛的,就表示该类具有“胖”接口.换句话说,类的“胖”接口可以分解成多组 ...
- 鸟哥的linux私房菜——第12章 正则表达式与文件格式化处理
12.1什么是正则表达式 正则表达式就是处理字符串的方法,它是以行为单位来进行字符串的处理行为,正则表达式通过一些特殊符号的辅助,可以让用户轻易达到查找.删除.替换某特定字符串的处理程序. vi.gr ...
随机推荐
- Nginx和Apache服务器上配置反向代理
在实际项目过程中,由于网站要用到一个在线编辑器(个性化的在线编辑软件),需要跨域进行通信!由于跨域通信较多,所以当时就想到在网站服务器上代理编辑软件的请求! 这就是“反向代理”的实际需求! 一.Ngi ...
- codevs 4093 EZ的间谍网络
时间限制: 10 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 由于外国间谍的大量渗入,学校安全正处于高度的危机之中.YJY决定挺身而作出反抗 ...
- 如何从桌面程序向浏览器传递cookie或自定义header
类似问题 从c#程序启动ie并传递cookie 打开默认浏览器并传递cookie 打开一个web浏览器使用c#应用程序并添加请求头 猜想 从wpf程序打开默认浏览器并定位到一个url ,并且向这个ur ...
- Java 设计模式之中介者模式
本文继续23种设计模式系列之中介者模式. 定义 用一个中介者对象封装一系列的对象交互,中介者使各对象不需要显示地相互作用,从而使耦合松散,而且可以独立地改变它们之间的交互. 角色 抽象中介者: ...
- UVALive 3523 Knights of the Round Table 圆桌骑士 (无向图点双连通分量)
由于互相憎恨的骑士不能相邻,把可以相邻的骑士连上无向边,会议要求是奇数,问题就是求不在任意一个简单奇圈上的结点个数. 如果不是二分图,一定存在一个奇圈,同一个双连通分量中其它点一定可以加入奇圈.很明显 ...
- Python——数据类型
如果是C语言,Java使用一个变量之前需要声明,数字,字符,布尔等都有特定的声明方式,前端中常用的js中都要使用var,而python中直接用就行了 比如: 虽然是这样使用,但其实是当你给一个变量赋值 ...
- linux之切换用户su(switch user)
1.切换至root su 或 su root然后输入密码 这种只切换身份,不切换home工作目录 su - 或 su - root然后输入密码 这种不仅切换身份,而且切换home工作目录 2.切换至普 ...
- redis基础知识学习
数据结构:1.String 添加: set key value get key getset key value (先get再set) incr key (key对应value原子性递增1) decr ...
- iOS 证书、真机调试、发布 App Store
之前对iOS的证书弄的很不清楚,Xcode里面也有各种证书,作为一只有强迫症的巨蟹座,这是不能忍的 趁着准备发布自己的第一个app,梳理一下这块内容 主要参考了这几篇文章: iOS开发:创建真机调试证 ...
- c++ 用指针操作数组
#include <iostream> using namespace std; const int Max = 5; double * fill_array(double * first ...