web布局——说清楚fixed布局

news2025/1/11 4:13:28

极限省流

想要fixed做导航页面:指定清楚top、left、right、bottom,没指定清楚布局位置就会采用默认的方式:

0)父元素的padding:fixed元素相对位移

1)同级元素是fixed元素:覆盖

2)同级元素有非fixed元素-》看它们的margin

使用总结:还是用top、left、right直接指定好

准备

准备好一个html文件和一个css文件

<!DOCTYPE html>
<html>
<head>
	<title>fixed理解</title>
	<link rel="stylesheet" type="text/css" href="./fixed_and_margin.css">
</head>
<body>

</body>
</html>

2)在css文件中写出fixed元素和非fixed元素(一般元素)做区分

.fixed_item{
	position: fixed;
	background-color: lightgreen;
}

.normal_item{
	background: lightblue;
	margin: 0px;
}

 3)为了看出fixed的效果,我们写一个obey样式,设定它的min-height,以便页面够长可以“测试滚动”

.obey{
	background: lightblue;
	margin: 0px;
	min-height: 500px;
}

一、fixed的固定效果

fixed脱离文档流——就是相对整个窗口浮动

fixed使得元素一直保持在屏幕的某一位置,不会随着滚轴在页面上的位移而改变

实例:

加两个占位元素以后,页面就足够长可以滚动了,滚动的时候会发现fixed元素一直在左侧

<!DOCTYPE html>
<html>
<head>
	<title>fixed理解</title>
	<link rel="stylesheet" type="text/css" href="./fixed_and_margin.css">
</head>
<body>
	
	<div class="fixed_item">
		首个fixed元素
	</div>
	<div class="obey">占位元素</div>
	<div class="obey">占位元素</div>
	
</body>
</html>

 

二、fixed布局

接下来以几个实例说明

1、之前的非flex元素

包括父元素和同级元素的height

htnl代码如下:

<body>
    <pre>
        空一行
        空一行
        fixed之前的pre元素
    </pre>
    <div class="fixed_item">
        首个fixed元素
    </div>
    <div class="fixed_item">
        紧接着的一个fixed元素
    </div>
    
    <div class="obey">占位元素</div>
    <div class="obey">占位元素</div>
</body>

效果显示:

①可以看出来“第一个fixed元素”已经看不到了,被"紧接着的一个fixed元素"遮挡了

 ②画面里仅有的一个fixed元素在<pre></pre>打完之后才出现,所以pre实体内容的高度会影响fixed元素的布局

2、margin

验证fixed只受其之前元素(包含父元素)和同级元素margin的影响

1)父元素的margin

 ①向html中加入一个fixed_item,发现fixed_item离左上角还有些距离

<!DOCTYPE html>
<html>
<head>
	<title>fixed理解</title>
	<link rel="stylesheet" type="text/css" href="./fixed_and_margin.css">
</head>
<body>
	
	<div class="fixed_item">
		首个fixed元素
	</div>
</body>
</html>

②将所有的margin清零

body{
	margin: 0px;
}

刷新得到效果:

结论:故fixed元素受其父元素的margin的影响

2)同级元素的margin

现在我们在fixed_item元素后增加一个<div>元素(类别认定为normal_item_wm,with mragin的意思):

<body>
	
	<div class="fixed_item">
		首个fixed元素
	</div>
	<div class="normal_item_wm">
	同级元素,带margin</div>
	<div class="obey">占位元素</div>
	<div class="obey">占位元素</div>

</body>

定制样式:为了突出显示,定margin为100px

.normal_item_wm{
	background: lightyellow;
	margin: 100px;
}

刷新结果显示:

结论:fixed元素的位置再一次发生了改变,说明同级元素的margin依然会影响到fixed的布局

3)子元素的margin

html中的代码是:

<body>
    <div class="fixed_item">
        首个fixed元素
        <div class="normal_item_wm">
            子元素,带margin</div>
    </div>
    <div class="obey">占位元素</div>
    <div class="obey">占位元素</div>
</body>

刷新效果如下:

补充:子元素也跟着fixed,脱离文档流

结论:fixed_item的位置不会受其自己的子元素的margin的影响

4)由2)和3)可以看出来margin是作用在直接的父子元素之间的

3、padding

先说结论:只有父元素的padding才会影响fixed_item的布局

1)父元素的padding

html代码:

<body>
    <div class="fixed_item">
        首个fixed元素
       </div>

    <div class="obey">占位元素</div>
    <div class="obey">占位元素</div>
</body>

css代码:

body{
	margin: 0px;
	padding: 100px;
}

显示效果:

 

2)同级元素的padding

<body>
    <div class="fixed_item">
        首个fixed元素
    </div>
    <div class="normal_item">
    	带padding的普通元素
    </div>

    <div class="obey">占位元素</div>
    <div class="obey">占位元素</div>
</body>

记得将body还原成默认css

/*body{
	margin: 0px;
	padding: 100px;
}*/
.fixed_item{
	position: fixed;
	background-color: lightgreen;
	margin: 0px;

}

.normal_item{
	background: lightblue;
	margin: 0px;
	padding: 100px;
}

效果如下图 

                                ​​​​​​​        ​​​​​​​        

4、直接指定位置

上述介绍中,可以看到默认情况下的fixed元素位置有太多的影响因素,因此我们需要一种直接指定位置的方式——[top,bottom,left,right](如果没有指定清楚某一方位,就会采用二的1-3默认布局)

html文件:

<body>
    <pre>
        空一行
        空一行
        fixed之前的pre元素
    </pre>
    <div class="fixed_item">
        首个fixed元素
    </div>
    <div class="obey">占位元素</div>
    <div class="obey">占位元素</div>

</body>

css文件

.fixed_item{
	position: fixed;
	background-color: lightgreen;
	margin: 0px;
	top:10px;
	left: 100px;
	right: 100px;

}


.obey{
	background: lightblue;
	margin: 0px;
	min-height: 500px;
}

三、fixed应该怎么用?

fixed可以使元素相对视角窗口固定,个人觉得非常适合用来做导航栏、侧边栏

其实在2.4的介绍中已经给出了fixed的基本用法,只是还存在问题:fixed浮空遮挡了pre的部分内容

可以给fixed对应位置“垫一个底板”,由于fixed已经直接指定了位置,所以不担心它会被底板影响布局

html中:

<body>
	<div class="navibg">
    <div class="navi">CSDN水平导航</div>
	</div>
    <pre>
    	pre开始
    	pre1
    	pre2
    	pre中间
    	pre3
    	pre结束

    </pre>
    <div class="helpnavi"></div>
   
    <div class="obey">占位元素1</div>
    <div class="obey">占位元素2</div>
</div>
</body>

css文件中

.navibg{
	height: 48px;
}
.navi{
	/*需求:占满屏幕*/
	height: 48px;
	background-color: lightgreen;
	position: fixed;
	left: 2px;
	right: 2px;
}

.obey{
	min-height: 500px;
}

效果显示:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1554394.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

.NET CORE 分布式事务(三) DTM实现Saga及高并发下的解决方案

目录(结尾附加项目代码资源地址) 引言&#xff1a; 1. SAGA事务模式 2. 拆分为子事务 3. 失败回滚 4. 如何做补偿 4.1 失败的分支是否需要补偿 5. 异常 6. 异常与子事务屏障 6.1 NPC的挑战 6.2 现有方案的问题 6.3 子事务屏障 6.4 原理 7. 更多高级场景 7.1 部分…

Golang-Gorm-快速上手

Gorm文档 GORM文档地址 安装依赖 go get -u "gorm.io/driver/mysql"go get -u "gorm.io/gorm"连接数据库 默认连接方式 func main() {// 参考 https://github.com/go-sql-driver/mysql#dsn-data-source-name 获取详情dsn : "user:passtcp(127.0.0…

Django自动化测试平台项目前端框架设计

引言 在之前根据项目具体情况&#xff0c;开发了一套自动预报数据的平台&#xff0c;但是前端页面不耐看&#xff0c;久了就生厌。于是就想更换前端框架&#xff0c;顺便记录一下。 前端设计 原来的界面&#xff1a; 一键预报模块&#xff1a; 为了有更好的感官体验&#xf…

设计模式——结构型——外观模式Facade

处理器类 public class Cpu {public void start() {System.out.println("处理器启动了...");} } 内存类 public class Memory {public void start() {System.out.println("内存启动了...");} } 硬盘类 public class Disk {public void start() {Syste…

单目图像加单点测距,求解目标位姿

单目图像加单点测距&#xff0c;求解目标位 附赠自动驾驶学习资料和量产经验&#xff1a;链接 单目相机通过对极约束来求解相机运动的位姿。参考了ORBSLAM中单目实现的代码&#xff0c;这里用opencv来实现最简单的位姿估计。 对极约束的概念可以参考我的这篇 Visual SLAM –…

总结TCP各类知识点

前言 本篇博客博主将详细地介绍TCP有关知识点&#xff0c;坐好板凳发车啦~ 一.TCP特点 1.有连接 TCP传输的过程中类似于打电话的各个过程 2.可靠传输 通过TCP自身的多种机制来保证可靠传输 3.面向字节流 内容是以字节的方式来进行发送与接收 4.缓冲区 TCP有接收缓冲区…

谈一谈BEV和Transformer在自动驾驶中的应用

谈一谈BEV和Transformer在自动驾驶中的应用 BEV和Transformer都这么火&#xff0c;这次就聊一聊。 结尾有资料连接 一 BEV有什么用 首先&#xff0c;鸟瞰图并不能带来新的功能&#xff0c;对规控也没有什么额外的好处。 从鸟瞰图这个名词就可以看出来&#xff0c;本来摄像头…

使用启智OpenI平台体验Open-Sora笔记

OpenI准备部分 镜像代码仓 创建云脑任务 新建调试任务 镜像选择 如果不想体验整个安装配置过程的话&#xff0c;我准备了一个Open-Sora的环境镜像应该可以直接开箱即用 地址&#xff1a; 192.168.204.22:5000/default-workspace/99280a9940ae44ca8f5892134386fddb/image:Open…

【C++的奇迹之旅】C++关键字命名空间使用的三种方式C++输入输出命名空间std的使用惯例

文章目录 &#x1f4dd;前言&#x1f320; C关键字(C98)&#x1f309; 命名空间&#x1f320;命名空间定义&#x1f309;命名空间使用 &#x1f320;命名空间的使用有三种方式&#xff1a;&#x1f309;加命名空间名称及作用域限定符&#x1f320;使用using将命名空间中某个成员…

NSGA算法

先给自己叠甲&#xff0c;记录自己的学习过程&#xff0c;如有内容错误欢迎指正!!!。 1. NSGA算法简介&#xff08;Nondominated Sorting Genetic Algorithm&#xff09; 根据标题&#xff0c;NSGA算法分为两个要点&#xff0c;Nondominated Sorting&#xff08;非支配排序&a…

基本数据类型

Oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645 数据类型是一种用于描述数据存储格式的结构。 PL/SQL 和其他编程语言一样也有多种数据类型&#xff0c;PL/SQL 语言中的常用数据类型和 Oracle 数据库中内置的数据类型基本…

基于JSP的母婴用品网站

背景 随着时代的飞速进步&#xff0c;计算机技术已经广泛而深刻地渗透到社会的各个层面。人们生活质量的持续提升&#xff0c;以及对母婴产品需求的日益增长&#xff0c;都推动了母婴用品网站开发的必要性和紧迫性。这类网站依托计算机技术&#xff0c;通过对相关产品信息的有…

简易挛生分拣系统设计

1 工效组合展示 2 方案规划设计 3 数字挛生建模 基础建模、动画设计、模型导出 4 软件体系架构 5 Web交互设计 5.1 页面架构 5.2 初始构造 5.3 模型运用 5.4 WS通信 5.5 运行展现 6 服务支撑编码 6.1 整体调度 6.2 WS服务 6.3 C/S通信 7 系统级调试完善

PyTorch深度学习快速入门(小土堆)

文章目录 16. 神经网络的基本骨架17.卷积操作18.卷积层 16. 神经网络的基本骨架 forward: import torch from torch import nnclass Tudui(nn.Module):def __init__(self):super().__init__()def forward(self,input):outputinput1return output#创建Tudui的实例对象 tuduiTu…

【详细讲解MNN介绍,安装和编译】

&#x1f308;个人主页:程序员不想敲代码啊&#x1f308; &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家&#x1f3c6; &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提…

基于Arduino IDE 野火ESP8266模块 定时器 的开发

一、delay函数实现定时 如果不需要精确到微秒级别的控制&#xff0c;可以使用Arduino的内置函数 millis()和delay() 来创建简单的定时器。millis()函数返回Arduino板启动后的毫秒数&#xff0c;而delay()函数会暂停程序的执行一段时间。 示例代码如下&#xff1a; delay()函数…

HarmonyOS实战开发-如何构建多种样式弹窗

介绍 本篇Codelab将介绍如何使用弹窗功能&#xff0c;实现四种类型弹窗。分别是&#xff1a;警告弹窗、自定义弹窗、日期滑动选择器弹窗、文本滑动选择器弹窗。需要完成以下功能&#xff1a; 点击左上角返回按钮展示警告弹窗。点击出生日期展示日期滑动选择器弹窗。点击性别展…

electron+VUE Browserwindow与webview通信

仅做记录 前言&#xff1a; electronVUEVITE框架&#xff0c;用的是VUE3.0 主进程定义&#xff1a;用于接收webview发送的消息 ipcMain.on(MyWebviewMessage, (event, message) > {logger.info(收到webmsg message)//转发给渲染进程}) porelaod/webPreload.js定义 cons…

Qt+OpenGL入门教程(二)——OpenGL渲染管线

渲染管线是图形学不可或缺的&#xff0c;在学习它之前&#xff0c;我们先了解一下什么是管线&#xff1f; 管线/流水线 当我们谈到管线时&#xff0c;我们指的是一个由多个阶段组成的过程&#xff0c;每个阶段都完成任务的一部分。在现实世界中&#xff0c;流水线的概念在许多…

vue实现文字一个字一个字的显示(开箱即用)

图示&#xff1a; 核心代码 Vue.prototype.$showHtml function (str, haveCallback null) {let timeFlag let abcStr for (let i 0; i < str.length; i) {(function (i) {timeFlag setTimeout(function () {abcStr str[i]haveCallback(abcStr)if ((i 1) str.length…