前端面试-关于position定位的哪些问答

yumo6661周前 (04-26)技术文章11

前端面试中,position定位绝对算是出现的频繁的一个面试题了,我们这次来共享下关于这个属性可以问出怎么样的问题。

CSS 的 position 属性用于控制元素的定位方式,共有五种值:

static、relative、absolute、fixed、sticky。

1. static(默认值)

特性:元素遵循常规文档流,top、left、z-index 等属性无效。

应用场景:默认布局,无需特殊定位时使用。

2. relative(相对定位)

特性:相对于元素自身在文档流中的原始位置偏移。不脱离文档流,原位置仍保留,不影响其他元素布局。常用于作为 absolute 子元素的定位参照物。

3. absolute(绝对定位)

特性:脱离文档流,不保留原位置,后续元素会占据其位置。相对于最近的定位祖先元素(非 static)定位;若无,则相对于 <body>。支持设置宽高,即使原为行内元素。

应用场景:下拉菜单、模态框等需要精准定位的元素。

4. fixed(固定定位)

脱离文档流,相对于浏览器视口定位,滚动页面时位置不变。常用于固定导航栏、返回顶部按钮。

5. sticky(粘性定位)

结合 relative 和 fixed,在跨越指定阈值前为相对定位,之后为固定定位。

需设置 top、left 等触发阈值,父容器不能有 overflow: hidden。

应用场景:吸顶导航、表格头部固定。

高频面试题

fixed和absolute的区别

定位的参照物不同,前者参照浏览器窗口,后者参照父祖元素。

sticky 的生效条件?

必须设置 top、left 等阈值。

父容器不能设置 overflow: hidden。

父元素高度需大于 sticky 元素高度。

如何实现元素垂直水平居中?

z-index 的生效条件?

仅对定位元素(非 static)有效。

层级由 z-index 值和 DOM 顺序共同决定。

奇怪的问题 position: fixed能否定位到浏览器窗口外的问题

不能。position: fixed 元素的定位范围严格受限于浏览器视口(viewport),无法通过设置 top、left 等属性将元素定位到视口可见区域之外。

相关文章

用CSS实现居中的七种方法

微信ID:WEB_wysj(点击关注) ◎ ◎ ◎ ◎ ◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)● ● ●在网页上使 HTML 元素居中看似一件很简单的事情. 至少在某些情况下是这样的,但是...

css之div内容居中

div中的内容居中显示,包括水平和垂直2个方向。<html> <head> <style type="text/css">...

CSS 元素分类与水平居中

元素分类在讲解CSS布局之前,我们需要提前知道一些知识,在CSS中,html中的标签元素大体被分为三种不同的类型:块状元素、内联元素(又叫行内元素)和内联块状元素。常用的内联元素有:<a>...

用CSS 实现元素垂直居中,有哪些好的方案?

水平居中方案:水平居中设置1、行内元素设置 text-align:center2、定宽块状元素设置 左右 margin 值为 auto3、不定宽块状元素a:在元素外加入 table 标签(完整的,包括...

html实现原生table并设置表格边框的两种方式

在 HTML 中实现原生表格并设置表格边框的详尽教程 在 HTML 中,表格是展示结构化数据的重要工具。为了使表格更加清晰、美观,设置表格边框是常见的需求。本文将深入探讨 两种原生方式 来实现表格边框...

实战经验分享:怎么在自己的网站里面调用第三方网站的页面内容

今日,站长在线(olzz.com)的首页右侧边栏里面,有一个是【mip验证】的工具入口,其实我在其他网站也放了这个入口,但是不同的是,以前的页面入口是直接链接到百度mip官方的页面检测地址的,而今天,...