前端CSS常考问题总结

目录

CSS盒模型

CSS选择器的优先级

隐藏元素的方法

px和rem的区别是什么?

重绘重排有什么区别?

重排(回流):

重绘:

浏览器的渲染机制:

浏览器如何解析CSS?

元素水平垂直居中的方式

CSS的哪些属性哪些可以继承

CSS预处理器

预处理器作用:

盒子塌陷

现象:

原因:

解决方案:

伪类和伪元素

伪类:

伪元素:

css3新特性

CSS3 边框

CSS3 背景

CSS3 文本效果

CSS3 字体

CSS3 2D 转换

用flex实现九宫格


CSS盒模型

在HTML页面中的所有元素都可以看成是一个盒子

盒子的组成:内容content、内边距padding、边框border、外边距margin

盒模型的类型:

  • 标准盒模型 margin + border + padding + content
  • IE盒模型 margin + content(border + padding)
标准盒模型
IE盒模型

控制盒模型的模式:

  • box-sizing:   ①content-box(默认值,标准盒模型) ②border-box(IE盒模型)

CSS选择器的优先级

CSS的特性

  • 继承性、层叠性、优先级

优先级

  • 写CSS样式的时候,会给同一个元素添加多个样式,此时谁的权重高就显示谁的样式

添加样式的方式

  • 标签、类/伪类/属性、全局选择器、行内样式、id、!important

优先级顺序

  • !important > 行内样式 > id > 类/伪类/属性 > 标签 > 全局选择器

隐藏元素的方法

  • display:none; ——元素在页面上消失,不占据空间
  • opacity:0; ——设置了元素的透明度为0,元素不可见,但仍然占据空间位置
  • visibility:hidden; ——让元素消失,占据空间位置,一种不可见的状态
  • position:absolute;——定位
  • clip-path——裁剪

px和rem的区别是什么?

px(像素):

  • 绝对单位长度,显示器上给我们呈现画面的像素,每个像素大小一样

rem:

  • 相对单位相对于html根节点的font-size的值
  • 默认html根节点font-size=16px,  1rem = 16px;
  • 直接给html节点的font-size:62.5%; 1rem = 10px; (16px*62.5%=10px)

重绘重排有什么区别?

重排(回流):
  • 布局引擎会根据所有的样式计算出盒模型在页面上的位置和大小
  • 对DOM的大小、位置进行修改后,浏览器需要重新计算元素的这些几何属性,就叫重排
重绘:
  • 计算好盒模型的位置、大小和其他一些属性之后,浏览器就会根据每个盒模型的特性进行绘制
  • 对DOM的样式进行修改,如color等,浏览器不需要重新计算几何属性时,直接修改绘制元素的新样式,就是重绘
浏览器的渲染机制:

浏览器如何解析CSS?
  • CSS选择器的解析是从右向左解析的。
  • 若从左向右的匹配,发现不符合规则,需要进行回溯,会损失很 多性能。
  • 若从右向左匹配,先找到所有的最右节点,对于每一个节点,向上寻找其父节点直到找到根元素或满足条件的匹配规则,则结束这个分支的遍历。
  • 两种匹配规则的性能差别很大,是因为从右向左的 匹配在第一步就筛选掉了大量的不符合条件的最右节点(叶子节点),而从左向右的匹配规则的性能都浪 费在了失败的查找上面。
  • 而在 CSS解析完毕后,需要将解析的结果与DOM Tree的内容-起进行分析建立一棵Render Tree,最终用来进行绘图。
  • 在建立Render Tree时(WebKit 中的「Attachment」过程), 浏览器就要为每个DOM Tree中的元素根据CSS的解析结果(Style Rules)来确定生成怎样的Render Tree

元素水平垂直居中的方式

1.定位+margin

.father{
            width: 400px;
            height: 400px;
            border: 1px solid;
            position: relative;
        }
.son{
            position: absolute;
            width: 200px;
            height: 200px;
            background-color: red;
            top: 0;
            right: 0;
            bottom: 0;
            left: 0;
            margin: auto;
        } 

2.定位+transform

.father{
            width: 400px;
            height: 400px;
            border: 1px solid;
            position: relative;
        }
.son{
            position: absolute;
            width: 200px;
            height: 200px;
            background-color: blue;
            top: 50%;
            left: 50%;
            transform: translate(-50%,-50%);
        } 

3.flex布局

.father{
            display: flex;
            justify-content: center;
            align-items: center;
            width: 400px;
            height: 400px;
            border: 1px solid;
        }
.son{
            width: 200px;
            height: 200px;
            background-color: green;
        }

4.grid布局

5.table布局

CSS的哪些属性哪些可以继承

CSS的三大特性:

  • 继承性
  • 层叠性
  • 优先级

子元素可以继承父类元素的样式 :

  • 字体的一些属性:font
  • 文本的一些属性:line-height
  • 元素的可见性:visibility:hidden
  • 表格布局的属性:border-spacing
  • 列表的属性:list-style
  • 页面样式属性:page
  • 声音的样式属性

CSS预处理器

预处理语言增加了变量、函数、混入等强大的功能

  • ①SASS    ②LESS
  • Sass 和 Less 都使用的是标准的 CSS 语法,因此如果可以很方便的将已有的 CSS 代码转为预处理 器代码,默认 Sass 使用 .sass 扩展名,而 Less 使用 .less 扩展名
预处理器作用:
  • 提供变量和函数等高级功能:CSS预处理器允许开发者使用变量和函数来组织和复用代码。这些高级功能使得样式表的编写更加灵活和高效。
  • 支持嵌套规则,简化代码结构:在CSS预处理器中,可以使用嵌套规则来简化代码结构。这使得样式表的编写更加清晰和易于理解。
  • 提供模块化和可复用的组件:CSS预处理器支持将样式表划分为模块和组件,从而提高代码的可复用性和维护性。这使得大型项目或复杂样式的管理更加有序和高效
     

Sass详细语法推荐:

【面试】css预处理器之sass(scss)_sass面试-CSDN博客

盒子塌陷

现象:

本应该在父盒子内部的元素跑到了外部。

原因:

当父元素没设置足够大小的时候,而子元素设置了浮动的属性,子元素就会跳出父元素的边界(脱离文 档流),尤其是当父元素的高度为auto时,而父元素中又没有其它非浮动的可见元素时,父盒子的高度 就会直接塌陷为零, 我们称这是CSS高度塌陷

解决方案:
  • 最简单,直接,粗暴的方法就是盒子大小写死,给每个盒子设定固定的width和height直到合 适为止,这样的好处是简单方便,兼容性好,适合只改动少量内容不涉及盒子排布的版面。缺点是非自 适应,浏览器的窗口大小直接影响用户体验
  • 给外部的父盒子也添加浮动,让其也脱离标准文档流,这种方法方便,但是对页面的布局不是很 友好,不易维护
  • 给父盒子添加overflow属性 overflow:auto; 有可能出现滚动条,影响美观。 overflow:hidden; 可能会带来内容不可见的问题
  • 用after伪元素清除浮动 给外部盒子的after伪元素设置clear属性,再隐藏它 这其实是对空盒子方案的改进,一种纯CSS的解决方案,不用引入冗余元素。
.clearfix {*zoom: 1;}
.clearfix:before,.clearfix:after {
display: table;
line-height: 0;
content: "";
}
.clearfix:after {clear: both;}

这也是bootstrap框架采用的清除浮动的方法。 这是一种纯CSS的解决浮动造成盒子塌陷方法,没有引入任何冗余元素,推荐使用此方法来解决CSS盒 子塌陷。 备注:第五种方法虽好,但是低版本IE不兼容,具体选择哪种解决方法,可根据实际情况决定。

  • 给父盒子添加border
  • 给父盒子设置padding-top

伪类和伪元素

伪类和伪元素存在的意义都是为了操作一些通过普通的CSS选择器无法直接取到的节点。它们都相当于CSS选择器的一种扩展

伪类:

用于已有元素处于某种状态时为其添加对应的样式

常用伪类:

  • :hover 鼠标悬浮的节点
  • :active 当前选中的节点
  • :enabled 启用的元素,通常用于表单
  • :focus 当前取的焦点的元素
  • :checked 选中的元素,通常用于表单 checkbox 元素
  • :disabled 未启用的元素,通常用于表单

例如:当用户悬停在指定元素时,可以通过:hover来描述这个元素的状态,虽然它和一般css相 似,可以为已有元素添加样式,但是它只有处于DOM树无法描述的状态下才能为元素添加样式, 所以称为伪类。

伪元素:

用于创建一些不在DOM树中的元素,并为其添加样式。

常用伪元素:

  • ::before 元素内容前插入新内容
  • ::after元素内容之后插入新内容
  • ::selection 选中的内容。常用于文本。
  • ::placeholder 占位符。用于设置占位符的样式。

例如,我们可以通过:before在一个元素之前添加一些文本,并为这些文本添加样式,虽然用 户可以看见 这些文本,但是它实际上并不在DOM文档中。

css3新特性

CSS3 边框

创建圆角

  • 语法: border-radius : length length;
  • length: 由浮点数字和单位标识符组成的长度值(如:20px)。不可为负值,如果为负值则与 0展示效果一样。第一个值设置其水平半径,第二个值设置其垂直半径,如果第二个值省略则默认 第二个值等于第一个值。

边框阴影 

  • 通过属性 box-shadow 向边框添加阴影。
  • 语法: {box-shadow : [inset] x-offset y-offset blur-radius extension-radius spread-radiuscolor} 说明:对象选择器 {box-shadow:[投影方式] X轴偏移量 Y轴偏移量 模糊半径 阴影扩展半径 阴影 颜色}

边框图片

  • 语法: border-image : border-image-source || border-image-slice [ / border-image-width] || border-image-repeat
  • border-image : none | image [ number | percentage]{1,4} [ / border-width>{1,4} ] ? [ stretch | repeat | round ]{0,2}
CSS3 背景

background-size 属性

  • 在 CSS3 之前,背景图片的尺寸是由图片的实际尺寸决定的。在 CSS3 中,可以设置背景图片的尺寸, 这就允许我们在不同的环境中重复使用背景图片。可以像素或百分比规定尺寸。如果以百分比规定尺 寸,那么尺寸相对于父元素的宽度和高度。

background-origin 属性

  • 规定背景图片的定位区域,背景图片可以放置于 content-box 、 padding-box 或 border-box 区域

background-clip 属性

  • 与 background-origin 属性相似,规定背景颜色的绘制区域,区域划分与 background-origin 属性 相同。

CSS3 多重背景图片

  • CSS3 允许为元素设置多个背景图像
CSS3 文本效果
  • text-shadow 属性 给为本添加阴影,能够设置水平阴影、垂直阴影、模糊距离,以及阴影的颜色。

  • text-wrap 属性 设置区域内的自动换行。 语法: text-wrap: normal | none | unrestricted | suppress | break-word

CSS3 字体
  • 在 CSS3 之前,web 设计师必须使用已在用户计算机上安装好的字体。但是通过 CSS3,web 设计师 可以使用他 们喜欢的任意字体。当找到或购买到希望使用的字体时,可将该字体文件存放到 web 服务 器上,它会在需要时 被自动下载到用户的计算机上。字体需要在 CSS3 @font-face 规则中定义。
CSS3 2D 转换

通过 CSS3 转换,我们能够对元素进行移动、缩放、转动、拉长或拉伸,转换是使元素改变形状、尺寸 和位置的一种效果。

  • translate() 方法 通过 translate(x , y) 方法,元素根据给定的 left(x 坐标) 和 top(y 坐标) 位置参数从其当前位置移 动,x为正值向右移动,为负值向左移动;y为正值向下移动,为负值向上移动;

  • rotate() 方法 控制元素顺时针旋转给定的角度。为正值,元素将顺时针旋转。为负值,元素将逆时针旋转

2D Transform 方法汇总

······(太多了不想写了😣😵‍💫)

用flex实现九宫格

  • 利用了padding-top和flex-wrap:wrap
  • 当设置background-color时,是包括盒子模型中的content和 padding的
  • 但是为什么不设置height呢?因为父元素没有高度,所以定义height:30%是没有用的
  • 且若想每个block都为正方形,最好的方式就是设置padding-top/padding-bottom:a%因为此时的百分比是父元素宽度的百分比,而width也为父元素宽度的百分比,所以block可以成为正方形
<!DOCTYPE html>
<html>
<style>
.block {
padding-top: 30%;
margin-top: 3%;
border-radius: 10%;
background-color: orange;
width: 30%;
}
.container-flex2 {
display: flex;
flex-wrap: wrap;
justify-content: space-around;
}
</style>
<body>
<div class="container-flex2">
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
<div class="block"></div>
</div>
</body>
</html>

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

VMwareWorkstation17.0虚拟机安装搭建PcDos2000虚拟机(完整图文详细步骤教程)

VMwareWorkstation17.0虚拟机安装搭建PcDos2000虚拟机&#xff08;完整图文详细步骤教程&#xff09; 一、PcDos20001.PcDos2000简介2.PcDos2000下载 二、创建PcDos2000虚拟机1.新建虚拟机2.类型配置3.类型配置4.选择版本5.命名、存位置6.磁盘容量7.调整虚拟配置7.1 调整虚拟配…

嵌入式学习 Day 29

函数: 1.函数的定义 2.函数的调用 3.函数的声明 1.函数传参: 1.赋值传递&#xff08;复制传递&#xff09; 函数体内部想要使用函数体外部变量值的时候使用复制传递 2.全局变量传递 3.地址传递 函数体内部想要修改函数体外部变量值的时候使用地址传递 函数…

Java多态性的作用及解析

多态性是 Java 面向对象编程的一个重要特性,它的主要作用包括以下几个方面: 提高代码的可扩展性:多态性使得我们可以在不修改现有代码的情况下,通过继承和重写方法来添加新的行为。这意味着我们可以在不影响现有功能的前提下,对代码进行扩展和修改。 增强代码的可读性:使…

STM32F103--基于正点原子的 FreeRTOS 移植(完整教程)附测试代码

前言 在看正点原子的FreeRTOS开发手册移植的时候&#xff0c;发现开发手册的描述并不全面&#xff0c;有几处遗漏。下面我展示出完整的教程&#xff0c;希望大家在学习的时候能够轻松点。 一、准备工作 1、正点原子的FreeRTOS官方资料 大家可自行到官方下载&#xff0c;或者在…

基于springboot+vue的健身房管理系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

FPGA之加法逻辑运算

由于FPGA需要被反复烧写&#xff0c;它实现组合逻辑的基本结构不可能像ASIC 那样通过固定的与非门来完成&#xff0c;而只能采用一种易于反复配置的结构。查找表可以很好地满足这一要求&#xff0c;目前主流FPGA都采用了基于SRAM 工艺的查找表结构。LUT本质上就是一个RAM。它把…

leetcode 热题 100_找到字符串中所有字母异位词

题解一&#xff1a; 滑动窗口&#xff1a;类似于字符串匹配&#xff0c;但匹配异位词需要包含相同的字母及个数&#xff0c;可以分别用两个数组存储字符串s滑动窗口和字符串p的字母及个数&#xff0c;再用Array.equals()进行比对。对于s.length()<p.length()的情况需要特判。…

【Linux】线程概念|线程理解|线程控制

文章目录 线程概念Linux中线程是否存在的讨论线程创建和线程控制线程的终止和等待&#xff08;三种终止方式 pthread_join()的void**retval&#xff09; 线程概念 线程就是进程内部的一个执行流&#xff0c;线程在进程内运行&#xff0c;线程在进程的地址空间内运行&#xff0…

Redis集群(主从)

1.主从集群 集群结构: 一.单机安装redis 1.上传压缩包并解压&#xff0c;编译 tar -xzf redis-6.2.4.tar.gz cd redis-6.2.4 make && make install 2.修改redis.config的配置并启动redis # 绑定地址&#xff0c;默认是127.0.0.1&#xff0c;会导致只能在本地访问。…

SpringBoot源码解读与原理分析(四十)基于jar/war包的运行机制

文章目录 前言第14章 运行SpringBoot应用14.1 部署打包的两种方式14.1.1 以可独立运行jar包的方式14.1.2 以war包的方式 14.2 基于jar包的独立运行机制14.2.1 可独立运行jar包的相关知识14.2.2 SpringBoot的可独立运行jar包结构14.2.3 JarLauncher的设计及工作原理14.2.3.1 Jar…

2核4G云服务器租用价格_2核4G云主机优惠价格_2024年报价

租用2核4G服务器费用价格&#xff0c;2核4G云服务器多少钱一年&#xff1f;1个月费用多少&#xff1f;阿里云2核4G服务器30元3个月、轻量应用服务器2核4G4M带宽165元一年、企业用户2核4G5M带宽199元一年&#xff1b;腾讯云轻量2核4G服务器5M带宽165元一年、252元15个月、540元三…

毕业生信息招聘平台|基于springboot+ Mysql+Java的毕业生信息招聘平台设计与实现(源码+数据库+文档+PPT)

目录 论文参考 摘 要 数据库设计 系统详细设计 文末获取源码联系 论文参考 摘 要 随着社会的发展&#xff0c;社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。 毕业生信息招聘平台&#xff0c;主要的模块包括查看管理员&a…

力扣经典题目解析--最小覆盖子串

原题地址: . - 力扣&#xff08;LeetCode&#xff09; 给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵盖 t 所有字符的子串&#xff0c;则返回空字符串 "" 。 注意&#xff1a; 对于 t 中重复字符&#xff0c;我们寻找…

Finetuning Large Language Models: Sharon Zhou

Finetuning Large Language Models 课程地址&#xff1a;https://www.deeplearning.ai/short-courses/finetuning-large-language-models/ 本文是学习笔记。 Goal&#xff1a; Learn the fundamentals of finetuning a large language model (LLM). Understand how finetu…

Vue3:用vite创建Vue3项目

一、简介 vite是新一代前端构建工具&#xff0c;官网地址&#xff1a;https://vitejs.cn vite的优势如下&#xff1a; 轻量快速的热重载&#xff08;HMR&#xff09;&#xff0c;能实现极速的服务启动。对 TypeScript、JSX、CSS 等支持开箱即用。真正的按需编译&#xff0c;不…

【计算机那些事】

目录 【云计算】 【原神用的是UDP还是TCP】 【几个特殊地址】 【socket是什么】 【内网穿透是什么】 【为什么有HTTP协议&#xff0c;还要有websocket协议】 【科普路由器&#xff0c;集线器&#xff0c;交换机&#xff0c;网桥&#xff0c;光猫】 【USB接口那些事】 …

MacOS包管理工具homebrew使用教程

MacOS包管理工具homebrew使用教程 1.概述与安装2.基本使用3.其他常用命令 1.概述与安装 homebrew是Mac OS X上的强大的包管理工具&#xff0c;可以高效管理各种软件包 安装&#xff1a; 1、安装xcode&#xff1a; xcode-select --install2、一行命令下载&#xff1a; /bin…

个人项目介绍3:火车站篇

项目需求&#xff1a; 一比一精确显示火车站主建筑和站台模型。实时响应车辆信息&#xff08;上水&#xff0c;吸污&#xff0c;换乘&#xff09;并同步显示&#xff0c;实时响应车辆进出站信息&#xff0c;并以动画形式模拟。实时响应报警信息&#xff0c;并能在三位中显示&a…

快速搭建Vue前端框架

快速搭建Vue前端框架 安装Vue Vue官方安装过程:https://cli.vuejs.org/zh/guide/installation.html 二.创建Vue工程 2.2 安装淘宝镜像 安装淘宝镜像&#xff08;会让你安装Vue的速度加快&#xff09;&#xff1a; npm config set registry https://registry.npm.taobao.or…

【内推】金山办公 2024届 春季校园招聘

有需要内推的小伙伴吗&#xff1f; 金山办公 各岗位均有 面向应届生春招 QQ群&#xff1a;723529936 内推码&#xff1a;NTASYQI