使用HTML+CSS编写一个灵活的Tab页

最近在研究CSS,正好结合项目做了一个灵活的Tab页,使用纯HTML+CSS实现,正好总结一下。 首先看一下预览界面: 样例HTML可以访问:http://www.demo2do.com/htmldemo/school/attendance/AttendanceGlobal.html 下面开始讲述一下完成上述页面的步骤。 1. 构建HTML 构建HTML是整个过程最基础的部分。我们构建HTML比较关键的一个原则就是“还HTML标签其本来的含义”。所以在这里,我们应该合理分析一下期望做到的HTML的结构的情况,并加以分析,选择比较合适的HTML标签,而不是采用非标准的Table布局或者充斥着大量div和class的布局方式。事实上,现在存在着一种误区,就是凡事采用了DIV+CSS的方式进行页面编程的就是Web标准的,其实这是完全错误的观点,很容易就导致了“多div症”(divitus)或者“多类症”(classitis)。 回到正题,我们分析一下页面样式,可以将整个Tab页分成2个部分,分别是一级菜单和二级菜单,他们有类似的特点,并以横向方式排列。HTML标签中的无序列表就可以反映出这种逻辑关系。所以我们分别采用2个无序列表来表示一级菜单和二级菜单。代码如下: 代码

< type="text/javascript">render_code(); 其中,2个div将菜单级别划分开。其实在以后还会有其他的功效。此时,我们不妨View一下这张页面,我们可以惊喜的发现,这张页面就想Word文档一样,是可读的,这一点我们可以在整个过程做完以后再一次验证。 2. 构建基本CSS 先简单的让ul横向排列,这里面要注意元素float之后要注意清理 然后通过分别在LI 和 A 元素上应用背景来实现主菜单样式,这里有个比较重要的地方是A这个元素变成块级元素(display: block),这样可以便于我们下面做一些处理,也能使整个菜单应用到链接样式。 而其中的line-height,恰恰可以使A中的字纵向居中。text-align使得A中的字横向居中。 代码 .navg .mainNavg UL { margin: 0; padding: 0; list-style: none; } .navg .mainNavg UL LI { float: left; background-color: #E1E9F8; background: url(../images/tab_right.gif) no-repeat right top; margin: 10px 3px; height: 25px; } .navg .mainNavg UL LI A { display: block; height: 25px; padding: 0 25px; line-height: 24px; background-color: #E1E9F8; background: url(../images/tab_left.gif) no-repeat left top; text-decoration: none; float: left; text-align:center; color: #fff; font-weight: bold; } < type="text/javascript">render_code(); 3. 使宽度自适应 我们在这里使用滑动门技术来做宽度自适应。下面简单介绍一下滑动门技术 简单来说,就是在LI上应用一幅大图像背景,并让这个背景居于右侧 然后在A上应用一个小图像背景,并让这个背景居于左侧,遮住大图像边缘 这样无论菜单文字内容长度怎么变,都不会破坏原来的结构了。 4. 当前菜单高亮显示 如果高亮当前页面,这个有很多种做法,最死板的是在每个页面上显式的定义类。 但是对于web项目来说,页面多数是动态的,所以这样不是最理想的方法。 我这里采用的方法是CSS选择器的灵活使用 代码 #attendance #attendanceNavg, #teach #teachNavg, #communication #communicationNavg, #system #systemNavg { background: url(../images/tab_right_on.gif) no-repeat right top; } #attendance #attendanceNavg A, #teach #teachNavg A, #communication #communicationNavg A, #system #systemNavg A { background: url(../images/tab_left_on.gif) no-repeat left top; color: #0000ff; } < type="text/javascript">render_code(); 在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用CSS编写一个基本的Tab切换效果,以下是一个简单的示例代码: HTML代码: ```html <div class="tab"> <button class="tablinks" onclick="openTab(event, 'tab1')">标签1</button> <button class="tablinks" onclick="openTab(event, 'tab2')">标签2</button> <button class="tablinks" onclick="openTab(event, 'tab3')">标签3</button> </div> <div id="tab1" class="tabcontent"> <h3>标签1</h3> <p>这里是标签1的内容。</p> </div> <div id="tab2" class="tabcontent"> <h3>标签2</h3> <p>这里是标签2的内容。</p> </div> <div id="tab3" class="tabcontent"> <h3>标签3</h3> <p>这里是标签3的内容。</p> </div> ``` CSS代码: ```css /* 隐藏所有标签内容 */ .tabcontent { display: none; } /* 标签按钮样式 */ .tab button { background-color: #fff; border: none; color: #000; cursor: pointer; padding: 8px 16px; } /* 激活标签按钮样式 */ .tab button.active { background-color: #ccc; } /* 显示当前标签内容 */ .tabcontent.show { display: block; } ``` JavaScript代码: ```javascript // 默认打开第一个标签 document.getElementById("tab1").classList.add("show"); function openTab(event, tabName) { // 隐藏所有标签内容 var i, tabcontent, tablinks; tabcontent = document.getElementsByClassName("tabcontent"); for (i = 0; i < tabcontent.length; i++) { tabcontent[i].classList.remove("show"); } // 取消所有标签按钮激活状态 tablinks = document.getElementsByClassName("tablinks"); for (i = 0; i < tablinks.length; i++) { tablinks[i].classList.remove("active"); } // 显示当前标签内容 document.getElementById(tabName).classList.add("show"); // 激活当前标签按钮 event.currentTarget.classList.add("active"); } ``` 在此示例中,我们首先定义了一些HTML元素,其中包括用于切换标签的按钮以及每个标签对应的内容。然后,我们使用CSS来定义标签按钮和标签内容的样式,并使用JavaScript来处理标签切换逻辑。最后,当用户单击标签按钮时,我们调用openTab函数来显示当前标签内容并激活当前标签按钮。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值