Css定位

news2024/11/24 19:14:53

定位

为什么需要定位?

提问:以下情况使用标准流或者浮动能实现吗?

  1. 某个元素可以自由的在一个盒子内移动位置,并且压住其他盒子。
  2. 当我们滚动窗口的时候,盒子是固定在屏幕的某个位置的

所以:

  1. 浮动可以让多个块级盒子一行没有缝隙排列显示,经常用于横向排列盒子
  2. 定位则是可以让盒子自由的在某个盒子内移动位置或者固定屏幕中某个位置,并且可以压住其他盒子。

定位组成:将盒子在某一个置,所以定位也是在摆放盒子,按照定位的方式移动盒子

定位=定位模式+边偏移。

定位模式用于指定一个元素在文档中的定位方式,边偏移则决定了该元素的最终位置。

定位模式:通过position属性来设置:

语义

Static

静态定位

Relative

相对定位

Absolute

绝对定位

Fixed

固定定位

边偏移:就是定位盒子移动到最终位置,有top、bottom、left、right4个属性

边偏移属性

示例

描述

Top

Top:80px

顶端偏移量,定义元素相对于其父元素上边线的距离

Bottom

Bottom:80px

底部偏移量,定义元素相对于其父元素下边线的距离

Left

Left:80px

左侧偏移量,定义元素相对于其父元素左边线的距离

Right

Right:80px

右侧偏移量,定义元素相对于其父元素右边线的距离

静态定位:static 是元素默认的定位方式,无定位的意思

语法:

选择器{position:static;}

静态定位按照标准流特性摆放位置,它没有边偏移

静态定位在布局时很少用到

相对定位:relative(重要)

相对定位时元素在移动位置的时候,是相对于它原来位置来说的(自恋型)

语法:

选择器{position:relative;}

相对定位的特点:

  1. 它是相对于自己原来的位置来移动的(移动位置的时候参照点是自己原来的位置
  2. 原来在标准流的位置继续占有,后面的盒子仍然以标准流的方式对待它(不托标,继续保留原来位置

因此,相对定位并没有脱标,它最典型的应用是给绝对定位当爹的

<!DOCTYPE html>

<html lang="en">



<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>相对定位</title>

    <style>

        .box1 {

            position: relative;

            top: 100px;

            left: 100px;

            width: 200px;

            height: 200px;

            background-color: aqua;

        }



        .box2 {

            width: 200px;

            height: 200px;

            background-color: pink;

        }

    </style>

</head>



<body>

    <div class="box1"></div>

    <div class="box2"></div>

</body>



</html>

绝对定位:absolute(重要)

绝对定位是元素在移动位置的时候,是相对于它祖先元素来说的(拼爹型)

语法:

选择器{position:absolute ;}

绝对定位的特点:

1.如果没有祖先元素或者祖先元素没有定位,则以浏览器为准定位(document)

2.如果祖先元素有定位(相对、绝对、固定定位),则以最近一级的有定位祖先元素为参考点移动位置。

3.绝对定位不再占有原先的位置(脱标)

<!DOCTYPE html>

<html lang="en">



<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>绝对定位</title>

    <style>

        .father {

            /* position: relative; */

            width: 400px;

            height: 400px;

            background-color: pink;

        }



        .son {

            position: absolute;

            top: 100px;

            right: 100px;

            width: 200px;

            height: 200px;

            background-color: aqua;

        }



        .son2 {

            width: 200px;

            height: 200px;

            background-color: aquamarine;

        }

    </style>

</head>



<body>



    <div class="father">

        <div class="son"></div>

        <div class="son2"></div>

    </div>



</body>



</html>

相对定位和绝对定位使用场景

为什么说相对定位给绝对定位当爹的呢

答:“子绝父相”是定位中最常用的一种方式:子级是绝对定位的话父级要用相对定位

    • 子级绝对定位,不会占有位置,可以放在父盒子里面的任何一个地方,不会影响其他的兄弟盒子。
    • 父盒子需要加定位限制子盒子在父盒子内显示。
    • 父盒子布局时,需要占有位置,因此父亲只能是相对定位。

这就是子绝父相的由来,所以相对定位经常用来作为绝对定位的父级

总结:因为父级需要占有位置,因此是相对定位,子盒子不需要占有位置,则是绝对定位

当然,子绝父相不是永远不变的,如果父元素不需要占有位置,子绝父绝也会遇到。

固定定位:fixed(重要)

固定定位是元素固定于浏览器可视区的位置。主要使用场景:可以在浏览器页面滚动时元素的位置不会改变。

语法:

选择器{position:fixed;}

固定定位的特点:

  1. 以浏览器的可视窗口为参照点移动元素。

跟父元素没有任何关系。

不随滚动条滚动。

  1. 固定定位不再占有原先的位置

固定定位小技巧:固定在版心右侧位置

小算法:

1让固定定位的盒子left:50% 走到浏览器可视区(也可以看做版心)的一半位置

2让固定定位的盒子margin-left:版心宽度的一半距离,多走版心宽度的一半位置

就可以让固定定位的盒子贴着版心右侧对齐了。

<!DOCTYPE html>

<html lang="en">



<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>固定定位小技巧</title>

    <style>

        .w {

            width: 800px;

            height: 1400px;

            background-color: pink;

            margin: 0 auto;

        }



        .fixed {

            position: fixed;

            /* 1走浏览器宽度的一半 */

            left: 50%;

            /* 2利用margin走版心的一半 */

            margin-left: 405px;

            width: 50px;

            height: 150px;

            background-color: aquamarine;

        }

    </style>

</head>



<body>

    <div class="fixed"></div>

    <div class="w">版心盒子 800px</div>

</body>



</html>

粘性定位sticky:(刚开始随着滚动条滚动,之后不会随着滚动条滚动,固定在屏幕的固定位置)

粘性定位可以被认为是相对定位固定定位的混合。Sticky粘性的

语法:

选择器{position:sticky;top:10px;}

粘性定位的特点:

1以浏览器的可视窗口为参照点移动元素(固定定位特点)

2粘性定位占有原先的位置(相对定位特点)

3必须添加top、left、right、bottom其中一个才有效

跟页面滚动搭配使用。兼容性较差,IE不支持。

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

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

相关文章

笨办法学 Python(第三版)习题 2: 注释和#号

参考书籍 代码 # -*- coding: utf-8 -*-# A comment, this is so you can read your program later. # Anything after the # is ignored by python.print("I could have code like this.") # and the comment after is ignored# You can also use a comment to &qu…

北京外国语大学2023年上半年公派英语高级培训班开始招生

教育部指定出国留学人员培训部的“培训班结业证书”是国家留学基金委&#xff08;CSC&#xff09;公派项目认可的外语水平证明文件之一。近日&#xff0c;北京外国语大学发出2023年上半年公派英语高级培训班招生简章。为方便培训者了解情况&#xff0c;知识人网小编特转载如下。…

LeetCode[112]路径总和

难度&#xff1a;简单 题目&#xff1a; 给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径&#xff0c;这条路径上所有节点值相加等于目标和 targetSum 。如果存在&#xff0c;返回 true &#xff1b;否则&#xff0c…

cookie

cookie Cookie是一个客户端会话技术&#xff0c;是由服务器端创建&#xff0c;放在响应头发送到客户端保存&#xff0c;用于存储少量数 据&#xff0c;因为存放在客户端中&#xff0c;容易被人编造伪造&#xff0c;不是很安全。一般不用于存储重要信息。它是通过键值对传递信…

载波通信在电网智能化中的应用

目录载波通信在电网智能化中的应用电力载波通信特点电力载波通信在电力智能化中应用载波数据通信载波语音通信高速电力线通信&#xff08;HPLC&#xff09;载波通信在电网智能化中的应用 电力载波通信特点 电力载波通信&#xff08;Power line Communication&#xff09;即PL…

Nginx防盗链

资源盗链 资源盗链指的是此内容不在自己服务器上&#xff0c;而是通过技术手段&#xff0c;绕过别人的限制将别人的内容放到自己页面上最终展示给用户。以此来盗取大网站的空间和流量。简而言之就是用别人的东西成就自己的网站。 案例 创建steal.html&#xff0c;页面引用两…

视频直播美颜SDK算法代码解析

随着短视频、直播软件一类app的流行&#xff0c;美颜sdk的应用也越来越广泛。所谓“美颜”&#xff0c;简单解释下&#xff0c;就是通过视频&#xff08;图片&#xff09;技术对人脸进行美化。但是就“美化”这个词&#xff0c;却牵扯到众多深度学习、图像处理、图像学技术。今…

vant-list上滑加载,数据重复,加载后返回顶部

&#xff08;1&#xff09;vant-list上滑加载 list这个组件&#xff0c;必须具有高度&#xff0c;才能实现上滑加载&#xff0c;不然不会有上滑加载的过程。 因为没有高度&#xff0c;相当于整个屏幕都是组件的&#xff0c;就没有底部一说&#xff0c;所以会一直加载所有的&…

Debye-Wolf积分计算器的用法

摘要 众所周知&#xff0c;Debye-Wolf积分可用于以半解析的方式计算焦平面附近的矢量场。Debye-Wolf积分通常用作分析高数值孔径显微镜成像情况的基本工具。 基于理想化模型&#xff0c;因此不需要精确的镜头规格即可进行计算。 该案例将说明如何在VirtualLab中使用Debye-Wolf积…

[力扣] 剑指 Offer 第三天 - 替换空格

[力扣] 剑指 Offer 第三天 - 替换空格题目来源题目描述示例题目分析算法代码实现执行结果复杂度分析总结耐心和持久胜过激烈和狂热。 题目来源 来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 链接&#xff1a;https://leetcode.cn/problems/ti-huan-kong-ge-lcof 著作…

什么是CUSDEC 报关单?

CUSDEC即Customs Declaration Message&#xff0c;中文解释是报关单&#xff0c;符合EDIFACT国际报文标准。 报关单信息 (CUSDEC) 允许将数据从报关员转移到海关管理部门&#xff0c;以满足有关进口、出口或过境货物申报的立法或操作要求。这个报文的应用场景还包括&#xff1…

【Hack The Box】windows练习-- Intelligence

HTB 学习笔记 【Hack The Box】windows练习-- Intelligence &#x1f525;系列专栏&#xff1a;Hack The Box &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f4c6;首发时间&#xff1a;&#x1f334;2022年9月7日&#x1f334; &…

C++11更新内容(2)--完美转发--默认移动构造/移动赋值--1116

1.完美转发 1.1万能引用 void Fun(int &x){ cout << "左值引用" << endl; } void Fun(const int &x){ cout << "const 左值引用" << endl; }void Fun(int &&x){ cout << "右值引用" << e…

分布式数据库Cassandra

目录 一、概述 1、简介 2、架构 3、使用场景 二、安装 三、基本概念 1、数据模型 列&#xff08;Column&#xff09; 列族 KeySpace 节点&#xff08;Node&#xff09; 集群&#xff08;Cluster&#xff09; 2、数据类型 基础类型 集合类型 自定义数据类型 …

Linux开发工具(3)——gcc/g++

文章目录Linux编译器——gcc/g程序编译背景知识gcc指令动态链接和静态链接Linux下运行其他语言Linux编译器——gcc/g 程序编译背景知识 程序的编译分为四步&#xff1a; 预处理&#xff1a;主要完成的是&#xff0c;头文件展开&#xff0c;宏替换&#xff0c;注释删除&#x…

基于Matlab使用GPU和代码加速杂波模拟(附源码)

目录 一、杂波模拟 二、比较杂波模拟时间 三、其他仿真时序结果 四、总结 五、程序 此示例演示如何在图形处理单元 &#xff08;GPU&#xff09; 上或通过代码生成 &#xff08;MEX&#xff09; 而不是 MATLAB 解释器来模拟混乱。该示例将样本矩阵反演 &#xff08;SMI&am…

DVWA靶场在sql注入联合查询时返回报错信息 “Illegal mix of collations for operation ‘UNION’ ”之解决

比如我们输入&#xff1a; -1 union select 1,table_name from information_schema.tables where table_schemadvwa#会跳出一个页面出现报错提示&#xff1a; Illegal mix of collations for operation UNION这是由于union连接数据库中的字段的字符规则不一样导致的错误&…

MySQL—Apache+PHP+MySQL实现网上社区

ApachePHPMySQL实现网上社区 所谓网上社区是指包括BBS/论坛、聊天室、博客等形式在内的网上交流空间&#xff0c;同一主题的网上社区集中了具有共同兴趣的访问者&#xff0c;由于有众多用户的参与&#xff0c;因此具备了交流的功能&#xff0c;成为一个营销场所。网上社区有各…

高质量实现单文件导入、导出功能(使用EasyExcel )

前言 咋说呢&#xff0c;最近交接了一个XXX统计分析系统到我手上&#xff0c;显示页面平平无其&#xff0c;一看导入、导出功能的实现代码&#xff0c;每个小菜单目录里面都对应一个导入导出接口&#xff0c;看起来十分难受&#xff01;&#xff08;此处省略1w字内心os&#xf…

Neo4j安装与配置

注意&#xff1a;在安装Neo4j之前要安装JAVA SE的SDK。 1. 下载Neo4j 企业版本的收费的&#xff0c;社区版本是免费的。我下载的是社区版本。 社区版本下载地址&#xff1a;https://neo4j.com/download-center/#community 我下载的是3.5.35 下载好以后是zip文件&#xff0c;…