文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

css的position怎么使用

2024-04-02 19:55

关注

这篇文章主要介绍了css的position怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇css的position怎么使用文章都会有所收获,下面我们一起来看看吧。

position

我们都知道元素都拥有 position 这个 css 属性,先来看看他的基本定义和可用值。

定义

position 决定了元素位置是如何被渲染的

可用值

static: 默认值,元素在文档流中依次渲染

absolute: 元素位置相对于其最近的非 static 的父元素

fixed: 元素位置相对于浏览器窗口

relative: 元素位置相对于原本应该渲染的位置

sticky: 根据滚动的位置在 relative 和 fixed 之间切换

initial: 设置为默认值

inherit: 从父元素继承

基本用法

<body>

  <section>

    <p>This is a paragraph!</p>

   </section>

</body>

body {

  background: beige;

}

section {

  display: block;

  width: 400px;

  height: 160px;

  background: lightgray;

}

p {

  width: 50%;   

  height: 25%; 

  margin: 5%;   

  padding: 5%; 

  background: cyan;

}

很好,与我们期望的一样渲染出来了。现在我们把 section 的 display 属性 换成 inline

section {

  display: inline;

  width: 400px;

  height: 160px;

  background: lightgray;

}

这个破坏真是立竿见影啊,为什么会这样呢?要知晓其中的奥秘,就要了解什么是内容块。

内容块

定义

通常情况下,元素的大小和位置都取决他的内容块。一般地,内容块是该元素最近的块级父元素,但有一些例外情况。

为什么内容块很重要

元素的大小和位置都是由其内容块做为参考的,他会影响到元素的 width, height, padding, margin 还有 offset 相关的属性。

如何找到元素对应的内容块

position 是 static 或者 relative 时,其内容块是其最近的块级父元素的内容框(content-box),比如 block, inline-block, list-item,或者是被指定为某种格式容器的元素,比如 table, flex, grid。

position 是 absolute 时,其内容块是其最近的 position 不是 static 的块级父元素的填充框(padding-box)。

position 是 fixed 时,其内容块是整个视图窗口(viewport)

position 是 absolute 或者 fixed 时,其内容块也可能是有下列特殊情况的最近的父元素的填充框(padding-box)。

transform 或者 perspective 被设置过或将被设置不为 none。

filter 被设置或将被设置不为 none。

从内容块计算百分比

height, top 和 bottom 依据内容块的 height 值进行百分比计算。如果内容块是 static 或者 relative,并且没有设置高度,依靠其内容决定高度,那么这些值都会变成 0。

width, left, right, padding, margin 依据内容块的 width 值进行百分比计算。

例子解释

现在我们了解了内容快的概念之后,再来看看上面的例子,p 最近的父元素是 section, 被设置为 inline 之后不再是块级元素,所以 body 变成了离 p 最近的块级父元素,此时内部的百分比计算都依据 body 的宽高做对应计算。

absolute的用例

我们再看看别的例子

现在我们将第一个例子中的 p 的 position 设置为 absolute, section 从 inline 改回 block,

body {

  background: beige;

}

section {

  display: block;

  width: 400px;

  height: 160px;

  background: lightgray;

}

p {

  position: absolute;

  width: 50%;   

  height: 25%; 

  margin: 5%;   

  padding: 5%; 

  background: cyan;

}

由于 p 设置为了 absolute, 显而易见他的大小尺寸都根据了浏览器窗口来计算,注意这里也经历了寻找内容块的过程。p 的祖先元素均是 static,所以浏览器窗口才成为了其内容块。

现在我们还不错,一切都在掌握之中,我们试着把 section 的 transform 设置为 rotate(0deg),旋转了 0 度,可以预计到本来应该没有视觉上的效果,但这么做会影响对内容块的决定,从而导致 p 的大小和位置变化。

section {

  transform: rotate(0deg);

  width: 400px;

  height: 160px;

  background: lightgray;

}

p {

  position: absolute;

  ...

}

看!由于我们为 section 设置了 transform,p 的内容块不再是浏览器窗口了,而是 section。

关于“css的position怎么使用”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“css的position怎么使用”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯