当前位置: 首页 > news >正文

【css】设置了margin-top为负数,div被img覆盖的解决方法

文章目录

    • 场景
    • 默认情况下,层叠顺序是如何工作的?
    • 为什么 img 会覆盖 div?
    • 解决方法

场景

<img src="image.jpg"> 
<div>Content</div>

有代码如上,img src是一个https网络图片链接。
若div的margin-top为负数,img会覆盖div。

默认情况下,层叠顺序是如何工作的?

默认情况下,CSS 的层叠顺序(z-index)是由元素在 HTML 中的出现顺序决定的:

  • 后出现的元素会覆盖先出现的元素。
  • 如果两个元素没有设置 z-index,那么它们的层叠顺序完全取决于 HTML 中的顺序。

即:后面的会覆盖前面的。

为什么 img 会覆盖 div?

经过实践,实际上是img会覆盖div。

因为图片加载的延迟

  • 如果 img 的加载速度较慢,它可能在页面布局完成后再显示出来。
  • 在图片加载完成之前,div 已经占据了页面上的某个位置。
  • 当图片加载完成后,它就覆盖在div上。

解决方法

给div设置:

position: relative;

原理:

默认情况下,一个元素没有z-index。设置了position: relative;后,这个元素有了z-index:auto

给div设置position: relative;z-index:auto就在没有z-index 上了。

若给img也设置:

position: relative;
z-index: 1;

则img覆盖div。因为 z-index: 1; > z-index:auto

相关文章:

  • 基于springboot的宠物服务预约系统
  • craw14ai 框架的入门讲解和实战指南——基于Python的智能爬虫框架,集成AI(如NLP/OCR)实现自动化数据采集与处理
  • 第七届人工智能技术与应用国际学术会议
  • AI时代SEO关键词革新
  • Python Beautiful Soup 4【HTML/XML解析库】 简介
  • MTEB:基于 Embedding 的文本分类评估与实战解析
  • 《HTTP权威指南》 第3章 HTTP报文
  • Codeforces Round 1032 (Div. 3)
  • 【Python】python系列之函数作用域
  • Linux head 命令
  • LINUX 619 NFS rsync
  • 嵌入式开发之freeRTOS移植
  • 令牌总线的工作原理
  • 声网对话式 AI:开启我的编程进阶之旅
  • 基于Python的房屋信息可视化及价格预测系统
  • 【程序员AI入门:趋势】22、AI发展全景解析:技术演进、行业变革与未来趋势深度洞察
  • 【MySQL】SQL基础
  • 分布变化的模仿学习算法
  • WEB3 的 WebSocket Provider连接方式
  • 模拟IC设计基础系列8-版图设计基础
  • go搭建网站/免费网站入口在哪
  • 石家庄商城网站搭建多少钱/站长数据
  • 电商网站首页怎么制作/武汉网站建设推广公司
  • 启迪网站建设/湖南网站托管
  • 溧阳企业网站建设价格/2023年国际新闻大事件10条
  • 湖北网站建设费用/网络销售就是忽悠人