css相对定位和绝对定位用法详解

本篇文章给大家带来的内容是关于css相对定位绝对定位用法详解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

再谈css相对定位和绝对定位用法

CSS relative相对定位

设置为相对定位的元素框会偏移某个距离。元素仍然保持其未定位前的形状,它原本所占的空间仍保留。

CSS 相对定位

立即学习“前端免费学习笔记(深入)”;

相对定位是一个非常容易掌握的概念。如果对一个元素进行相对定位,它将出现在它所在的位置上。然后,可以通过设置垂直或水平位置,让这个元素“相对于”它的起点进行移动。

如果将 top 设置为 20px,那么框将在原位置顶部下面 20 像素的地方。如果 left 设置为 30 像素,那么会在元素左边创建 30 像素的空间,也就是将元素向右移动。

#box_relative {position: relative;left: 30px;top: 20px;}

注意,在使用相对定位时,无论是否进行移动,元素仍然占据原来的空间。因此,移动元素会导致它覆盖其它框。

CSS 相对定位实例

h2.pos_left  {  position:relative;  left:-20px  }h2.pos_right  {  position:relative;  left:20px  }  

这是位于正常位置的标题

这个标题相对于其正常位置向左移动

这个标题相对于其正常位置向右移动

相对定位会按照元素的原始位置对该元素进行移动。

样式 "left:-20px" 从元素的原始左侧位置减去 20 像素。

样式 "left:20px" 向元素的原始左侧位置增加 20 像素。

0853290.gif

再谈css相对定位和绝对定位用法

2.定位的形象解释

我先来架设一个虚拟的场景:有一个矩形的房间,里面还有一个水桶装了些水,水里还浸泡着一个西瓜,这个房间半空中还有不少的钩子用于挂东西用。现在我把网页元素与上面物件对应上,那么房间就是一个网页,水桶是网页中的一个板块,桶中的水就是文本流,西瓜就是将要被定位的对象。

(1)贡献的绝对定位(absolute)

对照前面解释,如果西瓜被赋予绝对定位,那么就等于把西瓜从水中捞起来挂在半空中的钩子上,水桶中西瓜原来占用的空间水会自动填补它(绝对定位对象会让出自己原先占用位置,所以说它是贡献的)。此时如果之前没有对水桶进行定位设定,那么被拿起的西瓜位置不会再受水桶位置影响,水桶怎么移动,西瓜还是挂在原来位置,至于西瓜要怎放,则以房间左上角(body左上角)为准,用left,right,top,bottom值来定位。

但是如果水桶也给出了定位设置(通常是相对定位,下面有讲到这一实用技巧),此时西瓜的摆放就没有那么自由了,尽管此时西瓜被拿起来了不会影响水桶中的水(文本流),但它还是要听桶的话,桶会告诉西瓜“你可以活动,但应该在我的范围内走动,比方说我要你在我左上方1米处,你就要跟死这一点,我走你也要跟着走”,如果桶中有很多个西瓜,可以全部拿出来吊到半空中,它们将被安排在不同高度的空间(层),所以在房顶垂直往下看,有可能看到不同西瓜层叠在一起的情况(这个所谓的高度在网页中是不存在的,就像FLASH动画中的不同层上安排了元素,但它们在看时不会有深度感觉)。可见绝对定位的对象参考目标是它的父级,专业称之为包含块。

(2)自私的相对定位(relative)

相对定位一个最大特点是:自己通过定位跑开了还占用着原来的位置,不会让给他周围的诸如文本流之类的对象。相对定位也比较独立,做什么事它自己说了算,要定位的时候,它是以自己本身所在位置偏移的(相对对象本身偏移)。再拿前边作比如来解,那么此时西瓜似乎是有魔法的,如果西瓜通过相对定位在水桶中偏移了你会看到一个现实生活中不存在的现象:水中有一个地方水凹下去了,周围的水不能填补它,西瓜看起来在旁边,如果搅动一下桶中的水,那个凹的位置会发现改变 (文本流对相对定位对象还存在影响),但是凹处到西瓜出现的距离始终保持一致。可见文本流与它之间还会互相影响,因为对象并没有真正脱离文本流,就像有两个人在同一层楼水平移动的过程中会有碰头的机会。

(3)总结两种定位的特征

绝对定位就像是把不同对象安排到了一栋高楼的不同楼层(一般指不是第一层,我们这里理解为文本流就放在首层),它们互不影响,但是它们怎么移动与你楼的地基和面积(父级)有关。相对定位指对象还是在首层楼与文本流一起存放,它们之间肯定存在影响。

(4)对特殊情况的补充

在用相对定位和绝对定位的时候,有一种情况是它们的定位值用到了负值则对象可沿相反方向移动,刚才说到的把对象安排在一栋楼的不同层,如果某个对象一开始就是背靠着最外边墙的,此时再用一个负值定位它,它就会神奇般地跑出墙外去了,当然现实中可没有这种惊险而又神奇的事发生,本人只为了延用上面的比如作形象解释。

以上就是对css相对定位和绝对定位用法详解的全部介绍,如果您想了解更多有关CSS3教程,请关注PHP中文网。

以上就是css相对定位和绝对定位用法详解的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1613583.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
高手分享25个CSS网页布局实用小技巧
上一篇 2025年12月24日 03:45:44
CSS实现自适应宽度的菜单(代码实例)
下一篇 2025年12月24日 03:46:10

相关推荐

  • 如何使用 JS 实现渐进式进度条和三角形图片的渐进变化?

    使用 js 实现渐进式进度条效果 原进度条设计中,渐变方向错误,需要将其改为从左到右渐变。本文将使用 js 修改渐变效果,实现从左到右渐进的效果。 三角形图片的渐进式变化 除了进度条的渐变外,题主还希望让三角形上的图片也实现渐进式变化。根据题主补充的描述,可以使用 js 修改进度条的 -webkit…

    2026年5月10日
    000
  • js怎么控制页面打印样式 打印页面自定义样式技巧

    js怎么控制页面打印样式 打印页面自定义样式技巧js怎么控制页面打印样式 打印页面自定义样式技巧js怎么控制页面打印样式 打印页面自定义样式技巧js怎么控制页面打印样式 打印页面自定义样式技巧

    控制javascript页面打印样式的答案是使用css的@media print媒体查询和javascript动态修改样式。具体方法包括:1. 使用@media print定义打印样式,如隐藏元素、调整字体大小、修改链接样式;2. 利用javascript监听beforeprint和afterpri…

    2026年5月10日 用户投稿
    000
  • html如何制作水印_HTML水印(文字/图片)添加与设置方法

    使用CSS和HTML可实现网页水印,方法包括:一、通过background-image与data URI嵌入斜向文字水印;二、利用伪元素结合transform旋转生成叠加文字层;三、插入img标签或背景图设置固定位置图片水印;四、用Canvas绘制多行斜纹并转Base64作背景;五、通过禁用右键、屏…

    2026年5月10日
    100
  • CSS技巧:如何将元素固定在页面底部

    CSS技巧:如何将元素固定在页面底部CSS技巧:如何将元素固定在页面底部CSS技巧:如何将元素固定在页面底部CSS技巧:如何将元素固定在页面底部

    本教程旨在解决如何使用CSS将一个元素固定在网页底部的问题。我们将探讨使用position: absolute和position: fixed两种方法来实现这一目标,并解释每种方法的适用场景和注意事项。通过学习本文,你将能够灵活地控制元素在页面中的位置,从而创建更具吸引力和用户友好的网页布局。 在网…

    2026年5月10日 用户投稿
    000
  • 使用 CSS 创建箭头轮廓的技巧

    本文介绍了如何使用 CSS 为箭头形状创建轮廓效果。传统的 `outline` 属性会围绕整个元素盒子生成轮廓,而本文提供了一种使用 `box-shadow` 属性来模拟箭头轮廓的解决方案,并添加伪元素以完善轮廓的视觉效果,从而实现更精确的轮廓控制。 在 CSS 中,使用 outline 属性可以为…

    2026年5月10日
    000
  • 使用 CSS 实现图片悬停文字提示

    使用 CSS 实现图片悬停文字提示使用 CSS 实现图片悬停文字提示使用 CSS 实现图片悬停文字提示使用 CSS 实现图片悬停文字提示

    本教程详细介绍了如何使用 html 的 ` ` 和 “ 元素结合 css 实现图片悬停显示文本的交互效果。通过巧妙运用 css 动画和变换属性,当用户鼠标悬停在图片上时,图片会缩小、模糊,同时预设的文本内容平滑地淡入显示,从而提升用户界面的动态性和信息提示的友好性。 引言:图片悬停效果的重要性 在…

    2026年5月10日 用户投稿
    200
  • 在 Ionic 中实现聊天式输入框:多图标定位与布局优化

    本文旨在解决 Ionic 应用中聊天式输入框的布局难题,特别是如何在 ion-footer 内的 ion-input 组件中,正确地定位多个右侧图标按钮,同时避免图标重叠和文本流异常。通过采用 ion-toolbar 和 slot=”end” 等 Ionic 提供的布局机制,…

    2026年5月10日
    200
  • 如何使用动态单位和响应式布局解决页面大小变化导致图片位置飘移的问题?

    解决页面大小变化导致图片位置飘移 问题中提到使用绝对定位后,页面大小变化时图片位置出现漂移。这种情况下,可以考虑以下方法: 使用动态单位配合响应式布局 动态单位: vw:浏览器内置单位,100vw 等于页面可视宽度。rem:相对于根元素()的字体大小。 响应式布局: 使用 @media 媒体查询,针…

    2026年5月10日
    000
  • CSS布局技巧:如何高效实现块级元素的水平居中

    本教程详细介绍了在CSS中实现块级元素水平居中的标准方法。通过使用`margin: auto;`属性,结合明确的`width`定义,开发者可以轻松地将`div`、`header`等块级元素在其父容器中水平居中。文章将提供清晰的代码示例和关键注意事项,帮助您掌握这一基础而重要的CSS布局技术。 在网页…

    2026年5月10日
    000
  • JavaScript动画中定位属性的过渡陷阱与解决方案

    本文深入探讨了javascript动画中css定位属性 `left` 和 `right` 同时使用时可能引发的过渡失效问题。文章通过一个卡片移动动画的案例,解释了浏览器处理这些冲突属性的机制,并提供了实用的解决方案:在执行水平方向的过渡动画时,应避免同时设置 `left` 和 `right`,建议仅…

    2026年5月10日
    100
  • CSS图像定位:实现水平居中与垂直下移的实用指南

    CSS图像定位:实现水平居中与垂直下移的实用指南CSS图像定位:实现水平居中与垂直下移的实用指南CSS图像定位:实现水平居中与垂直下移的实用指南CSS图像定位:实现水平居中与垂直下移的实用指南

    本教程详细阐述了如何使用css精确控制图像的水平居中和垂直下移。文章深入探讨了外边距(margin)、内边距(padding)以及定位(position)属性的应用,并提供了清晰的代码示例,帮助开发者理解并掌握图像布局的各种技巧,避免常见误区,从而创建响应式且美观的网页设计。 在网页设计中,精确控制…

    2026年5月10日 用户投稿
    000
  • 优化绝对定位的不足,掌握灵活运用的方法!

    绝对定位是CSS中一种常见的定位方式,通过给元素设置top、bottom、left、right等属性,将元素精确地定位在页面上的指定位置上。然而,尽管绝对定位有其独特的优势,但也存在一些不足之处。本文将探究绝对定位的不足,并分享一些灵活运用的技巧,以便在实际开发中能更好地应用。 首先,绝对定位的一个…

    2026年5月10日
    000
  • CSS响应式布局:利用VW单位优化文本定位与尺寸

    本教程旨在解决CSS响应式布局中,文本内容在不同屏幕尺寸下定位不准确、易重叠的问题。我们将探讨如何利用CSS的`vw`(viewport width)单位实现文本尺寸的自适应,并结合其他布局技巧,确保文本始终保持在预期位置,避免与图片等其他元素冲突,从而提升用户体验。 响应式文本与定位挑战 在构建现…

    2026年5月10日
    100
  • 如何解决HTML表格布局混乱的处理方法

    首先检查HTML标签结构是否完整,确保table、thead、tbody、tr、th、td正确嵌套;其次通过CSS设置table-layout: fixed、border-collapse: collapse,并避免使用float或absolute定位;最后为适配移动端,可在外层容器添加overfl…

    用户投稿 2026年5月10日
    000
  • 如何精确控制CSS文本元素底边框的起始与长度

    本教程旨在详细阐述如何在CSS中精确控制文本元素(如` `)的底边框起始位置和长度,避免其默认的延伸行为。文章将介绍两种主要方法:通过调整内边距和移除固定宽度使边框适应内容,以及利用CSS伪元素(`::after`)实现像素级的精细定位和宽度控制,从而满足多样化的设计需求。 在网页设计中,为标题或文…

    2026年5月10日
    000
  • HTML如何设置全屏控制样式?fullscreen-controls伪类的作用是什么?

    要实现全屏控制样式,最有效的方法是放弃原生控件并创建自定义ui,具体步骤为:1. 使用javascript的fullscreen api(如element.requestfullscreen()和document.exitfullscreen())控制全屏状态;2. 隐藏原生控件,例如通过设置vid…

    2026年5月10日
    000
  • 如何使用CSS让图片不撑高父元素?

    巧用CSS,图片不再撑高父元素 前端布局中,控制元素高度是常见挑战。例如,父容器包含文字和图片,我们希望父容器高度仅受文字影响,图片高度不干扰。本文将介绍纯CSS解决方案。 父容器被子元素撑高的原因在于:子元素(图片或文字)未脱离文档流,且父元素高度未固定。因此,最大高度的子元素决定父元素高度。 基…

    2026年5月10日
    000
  • 如何使用CSS Flexbox将导航栏精确地定位到右侧

    本教程详细介绍了如何利用CSS Flexbox技术,将网页导航栏(Nav Bar)精准地定位到容器的右侧,同时保持其背景透明。文章通过分析常见的布局问题,提供了基于Flexbox的优化解决方案,并深入解析了display: flex、flex-direction和align-items等关键CSS属…

    2026年5月10日
    000
  • 使用 CSS Scroll Snap 实现目标元素后微调对齐

    本文旨在解决在使用 CSS Scroll Snap 功能时,如何使滚动捕捉位置略微偏移目标元素之后的问题。通过创建一个绝对定位的空 div 元素,并将其设置为滚动捕捉点,可以有效地实现对滚动捕捉位置的微调,从而隐藏特定视觉元素或达到其他设计目的。 在使用 CSS Scroll Snap 时,有时我们…

    2026年5月10日
    000
  • 利用CSS Grid实现复杂嵌套结构水平重排

    本文详细介绍了如何将一个包含主方块和两个底部小方块的嵌套结构,通过CSS Grid布局实现水平重排,使小方块垂直堆叠在主方块的旁边。教程对比了Flexbox在处理此类二维布局时的局限性,并深入讲解了CSS Grid的`grid-template-columns`、`grid-template-row…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信