前言, 虽然jQuery的tab已经做得很好了,
但作为一个代码手写者, 多少有些洁癖,
为了1,2个小功能就要在打开的网页里下载几十乃至几百K的js lib, 心里不是滋味, 想想我自身的代码才多少, 本末倒置
但jquery的风格着实不错, 就参照写了个类似的, 以备日后自己回顾
//load custom lib
<script type="tetext/javascript" src="YS_Util.tab.js"></script>
//invoke
//parameter: name of select tag, name of container tag, className of selected tag
function demo(){
$YS_Util.tab.createTab("tab_li", "tab_div", "selected");
}
其实要实现tab控件并不难, 就是几个title的选择点击, 然后下面一个容器里, 选择对应的block, 其余的none
比较花时间的是, 有个好的封装, 和漂亮的UI, 但漂亮的UI主要是靠图片, 把时间耗在JS上还不如用PS和AI
(function(){
var Tab=new Object();
$YS_Util=new Object();
$YS_Util.tab=Tab;
var li=new Array(); //save select tag
var div=new Array(); //save container div
var alterClassName; //className of selected
/**
* perform tab component in js like GUI tabcomponent
* @param tab_lbl name attribute of select button
* @param tab_div containers' name attribute
* @param className
*/
Tab.createTab=function(tab_lbl, tab_div, className){
try{
alterClassName=className;
var e=document.getElementsByName(tab_lbl);
var len=e.length;
for(var i=0;i<len;i++){
li.push(e[i]);
e[i].onclick=show;
e[i]._no=i;
}
e=document.getElementsByName(tab_div);
len=e.length;
for(var i=0;i<len;i++){
div.push(e[i]);
e[i].style.display="none";
}
//initial setting, default display 1st tag & div
li[0].className=alterClassName;
e[0].style.display="block";
}catch(err){
alert(err);
}
}
var show=function(){
try{
for(i in li){
li[i].className="";
}
li[this._no].className=alterClassName;
for(i in div){
div[i].style.display="none";
}
div[this._no].style.display="block";
}catch(err){
alert(err);
}
}
})();
html demo
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Tab Conponent Demo</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script type="text/javascript" src="YS_Util.tab.js"></script>
<style type="text/css">
#tab li
{
display: table-cell;
padding-left: 20px;
padding-right: 20px;
background-color: bisque;
cursor: pointer;
}
#tab li.selected {background-color: burlywood;}
#tab>div
{
border: solid #777 0px;
background-color: burlywood;
}
</style>
<script type="text/javascript" >
function demo(){
$YS_Util.tab.createTab("tab_li", "tab_div", "selected");
}
</script>
</head>
<body onload="demo()" >
Tab Conponent Demo<br /><br />
<div id="tab">
<li name="tab_li" >JS</li>
<li name="tab_li" >CSS</li>
<li name="tab_li" >JAVA</li>
<li name="tab_li" >SQL</li>
<div>
<br />
<div name="tab_div">jquery<br />EXT<br />regular<br /></div>
<div name="tab_div">table<br />list<br />layout<br />border<br />selector</div>
<div name="tab_div">String<br />Integer<br />Collection<br /></div>
<div name="tab_div">PL-SQL<br />T-SQL</div>
</div>
</div>
</body>
</html>
其实不一定要li+div, 用table实现也是不错的, 第一行做title, 第二行合并全部单元格做container,
对于设置标签和容器等宽很方便
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script type="text/javascript" src="YS_Util.tab.js"></script>
<style type="text/css">
table {table-layout: fixed; border-collapse: collapse; width: 400px}
table tr.title td {border: solid #777 1px; text-align: center; background-color: burlywood; cursor: pointer;}
table tr.title td.selected {border-bottom: 0px; background-color: bisque;}
table td[colspan="4"] {border: solid #777 1px; border-top: 0px; background-color: bisque;}
</style>
<script>
function demo(){
$YS_Util.tab.createTab("tab_td", "tab_div", "selected");
}
</script>
</head>
<body onload="demo()" >
TAB COMPONENT DEMO2<br /><br />
<table>
<tr class="title" >
<td name="tab_td">JS</td>
<td name="tab_td">CSS</td>
<td name="tab_td">JAVA</td>
<td name="tab_td">SQL</td>
</tr>
<tr>
<td colspan="4">
<div name="tab_div">jquery<br />EXT<br />regular<br /></div>
<div name="tab_div">table<br />list<br />layout<br />border<br />selector</div>
<div name="tab_div">String<br />Integer<br />Collection<br /></div>
<div name="tab_div">PL-SQL<br />T-SQL</div>
</td>
</tr>
</table>
</body>
</html>
效果如图, 只简单写了点CSS配色, 笔记就懒得PS了
- 大小: 191 KB
- 大小: 168 KB
分享到:
相关推荐
最近在写一个小程序,jre1.8.0_181整整有199mb,对于一个只有400多k的程序来说,完全没必要,于是就进行精简,把jre精简到40M、左右,程序也能正常运行。如果你急需使用精简的jre,可以下载试试。
【精简版】十四五规划精简版.rar
本压缩包包含三个文件: ①RT 7 Lite的配置文件;(X86/X64系统通用) ②手动精简Win 7的驱动; ③Win SXS的再精简批处理。 使用方法: ①首先使用Rt7 Lite加载配置文件对提取出来的ISO文件进行精简; ②加载...
Sam机架精简版+精选插件 精简后再加几十个精选插件 精简版运行速度快
或者说,根本就不存在精简它的必要,又何必想要去精简呢? 然而,当你的软件最终不是面向企业,而是面向个人用户时,那么JRE的安装就绝对成了问题。 这里完全详解了如何把所有的东东打包成一个exe,且是最精简的...
国行官方2.3.6精简列表.xls 精简使用很方便
最近在写一个java开发的游戏,jre1.8.0_181整整有199mb,对于一个只有400多k的游戏来说,完全没必要,于是就进行精简,把jre精简到22.5mb,游戏也能正常运行。如果你急需使用精简的jre,可以下载试试。本来想精简到...
易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版易语言5.1精简版
VB精简版软件,无需更复杂的库即可使用,用于精简化的功能。
mb525 defy国行rom2.2精简列表
卓普精简列表 注意精简 小心专机。刷底包解决
dietlibc是一个精简的libc库,起源码比glibc要容易阅读得多,是提高C编程技能的好东西!
PPC手机 SU2U键盘锁(精简版) PPC自带的键盘锁是公认的难用.试一下SU2U键盘锁吧.只有600多K
jquery 精简版 jquery 精简版 jquery 精简版jquery 精简版 jquery 精简版 jquery 精简版 jquery 精简版
jre8 官方精简后的 compat,按照精简程度包含compat1-3三个级别。。。
VC10 精简版(只有编译器,标准库,必要的lib) 从VS2010 beta版提取
易语言超级精简版 易语言超级精简版易语言超级精简版易语言超级精简版易语言超级精简版易语言超级精简版
vb6精简版vb6精简版vb6精简版vb6精简版vb6精简版
matlab6.5 精简版 精简版