选项卡制作问题--折磨了我一整天,记录下来

2024-09-08 04:32

本文主要是介绍选项卡制作问题--折磨了我一整天,记录下来,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

看老曹的html+css课程,学习html+css基础,讲到制作选项卡,以京东商城的选项卡为例,效果如下:


看着他做出来很简单,结果自己做花了2个多小时才有个样子,效果是这样的:


内部代码如下

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>行高样式</title><style type="text/css">#mt ul li{float:left;width:85px;height:35px;text-align:center;line-height:35px;list-style:none;position:relative;z-index:8;}#mt ul li a{text-decoration:none;display:block;height:33px;z-index:9;}#mt ul li span{display:block;background:gray;height:18px;width:1px;overflow:hidden;top:10px;position:absolute;left:0px;z-index:8;}#mt{border-bottom:1px solid red;height:35px;width:1200px;}ul ,li{margin:0px;padding:0px;border:0px;}#mt ul{border:1px solid gray;height:35px;border-bottom:none;margin-left:20px;margin-right:40px;}.select_li a{display:block;border:1px solid red;border-top:3px solid red;position:absolute;width:85px;z-index:9;top:-1px;left:-1px;border-bottom:none;background:white;}</style>
</head>
<body ><!--  line-height:  字体高度/2 0/2 =0;--><div id="mt"><ul><li class="select_li"><a href="#">首页</a><span></span></li><li><a href="#">鞋子</a><span></span></li><li><a href="#">大衣</a><span></span></li><li><a href="#">内衣</a><span></span></li><li class="select_li"><a href="#">帽子</a><span></span></li><li><a href="#">婴儿</a><span></span></li><li><a href="#">妇幼</a><span></span></li></ul></div></body>
</html>

a标签的右边框始终覆盖不了span,这让我头疼,由于不熟悉,我考虑了一万种可能,结果搞了一晚上没结果,第二天继续搞了一晚上还是不行,第二天上班抽时间还在想,

甚至发到群里求助,可是没人回应,结果无意间(其实经过深思熟虑的尝试)我把span标签的left:0px;改成了right:0px;就好了!!!

现在的效果是这样的


总结:

1.z-index只对在同一个容器内的元素有作用,不是同一容器没有用

2.span的left:0px;造成a左边框覆盖的是所在li下的span,而右边框上的a是后面一个lib下的span,所以z-index没用,span依然显示在a右边框上

3.那为啥span改成right:0px;就好了呢,为啥span不覆盖后边lib下的a了呢?原来浏览器默认同一容器的元素先渲染的z-index就低,即后渲染的覆盖先渲染的,因为ul下面的lib元素是左浮动,所以是由左向右渲染的,自然右边的lib的z-index要比左边高。为了验证我的想法,我把lib都改成右浮动(还要调整下才能正常覆盖),结果就是


这时将span改成left:0px,看看效果:


结果证明我的想法是对的!

这篇关于选项卡制作问题--折磨了我一整天,记录下来的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147119

相关文章

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

Linux部署中的文件大小写问题的解决方案

《Linux部署中的文件大小写问题的解决方案》在本地开发环境(Windows/macOS)一切正常,但部署到Linux服务器后出现模块加载错误,核心原因是Linux文件系统严格区分大小写,所以本文给大... 目录问题背景解决方案配置要求问题背景在本地开发环境(Windows/MACOS)一切正常,但部署到