挑战css基础面试题

news2024/11/24 4:22:35

挑战css基础面试题一,看看你能做出来吗

文章目录

  • 前言
  • 一、盒模型
  • 二、如何实现一个最大的正方形
  • 三、文本一行水平居中,多行居左
  • 四、画一个三角形
  • 五、BFC理解
  • 六、两栏布局,左边固定,右边自适应,左右不重叠
  • 最后


前言

本片文章主要是复习并,挑战css基础面试题,都说前端最难的就是css🐶


一、盒模型

解析:考察css盒模型,所以多半是对设置不同box-sizing属性后,元素实际宽度的变化的问题。
1、红色区域的大小是多少
html部分:
一个div,有class为box

<div class="box"></div>

css部分:
设置宽度,高度,padding,margin,border

.box {
  width: 200px;
  height: 200px;
  padding: 20px;
  margin: 20px;
  background: red;
  border: 20px solid black;

  /*IE模型 -- 为此模型时红色区域大小为width 160=200-20*2 */
  box-sizing: border-box;

  /* 标准模型 -- 为此模型时红色区域大小为width 240=200+20*2 */
  // box-sizing: content-box;
}

效果图:
content-box:
可以看到它红色的区域是包含padding的,但是元素的实际width扩大了。
而红色的区域宽度如图是,240px在这里插入图片描述
border-box:
可以看到它红色的区域是包含padding的,但是width并没有扩大,反而是保持了200px。而红色的区域的宽度如图是,160px
在这里插入图片描述

二、如何实现一个最大的正方形

解析:首先需要理解的是怎么能在页面上面画一个最大的正方形,就是要让这个正方形,充满整个页面才为最大。由于不能保证所有页面是正方形的,所以当页面为长方形时,有一个方向元素不会充满整个页面。

html部分:
一个div有class为section

<div class="section"></div>

css部分:
让width自适应,高度同宽度一样的内边距来撑开,当然用padding-bottom也可以。

.section {
  width: 100%;
  padding-top: 100%;
  background: #333;
}

三、文本一行水平居中,多行居左

解析:根据题意可知,文本需要自动适配单行显示和多行显示,并且需要实现多行时居左,一行居中显示。
分析:我们知道span标签里的文本,默认的特性就是不管单行还是多行都是居左显示的,所以就要想怎么能让文本在一行的时候还能居中显示。所以既然是文本的话那么就很容易想到使用text-align:center属性。
html部分:

<div>
  <span>
    我是多行文字。我是多行文字。我是多行文字。我是多行文字。我是多行文字。我是多行文字。我是多行文字。我是多行文字。我是多行文字。我是多行文字。
  </span>
</div>

css部分:
div设置center为了让文本居中,span设置left是因为span会继承div的center所以需要设置left。设置display: inline-block;是因为span为行内元素,需转变为行内块元素,可以在父元素中指定span元素的宽度。

div {
  text-align: center;
}

div span {
  display: inline-block;
  text-align: left;
}

四、画一个三角形

解析:直接通过元素或者设置css属性并不能实现,所以得通过其他的方法来,实现视觉上的效果。
html部分:

<div class="angle"></div>

css部分:
当把边框设置的足够大,占满整个元素,那么会形成不同方向的三角形。最后配合transparent可以实现单个三角形

.angle {
  width: 100px;
  height: 100px;
  border-bottom: 100px solid #333232;
  border-top: 100px solid rgb(73, 59, 232);
  border-left: 100px solid rgb(177, 212, 36);
  border-right: 100px solid rgb(188, 97, 44);
  box-sizing: border-box;
}

效果:
在这里插入图片描述

五、BFC理解

解析:区块格式化上下文(Block Formatting Context,BFC)
分析:这里先简单补充一下之前写过文章中不太细节的东西。

网格元素display 值为 grid
作用:
1、元素内部包含浮动
2、元素周围浮动
3、外边距重叠
因为元素浮动和重叠和边距失效导致的页面显示异常的问题,可以使用可以创建BFC的属性,来解决整个问题。
BFC是什么—>

六、两栏布局,左边固定,右边自适应,左右不重叠

解析:如题,左侧的宽度需要固定,右侧需要自适应宽度
html部分:

<div class="sencod-grid">
 <div class="left"></div>
  <div class="right"></div>
</div>

css部分:
方法三就是利用了创建bfc实现

.sencod-grid {
  width: 100vw;
  height: 100vh;
  background-color: antiquewhite;

  // 方法一
  // .left {
  //   width: 500px;
  //   height: 100vh;
  //   background-color: aqua;
  // }
  // .right {
  //   width: 50%;
  //   height: 100vh;
  //   background-color: rgb(230, 230, 64);
  //   flex: 1;
  // }
  // 方法二
  // .left {
  //   float: left;
  //   width: 200px;
  //   height: 100vh;
  //   background-color: aqua;
  // }

  // .right {
  //   margin-left: 200px;
  //   height: 100vh;
  //   background-color: rgb(230, 230, 64);
  // }
  // 方法三
  .left {
    float: left;
    width: 300px;
    height: 100%;
    margin-right: 10px;
    background: red;
  }

  .right {
    height: 100%;
    overflow: hidden;
    /* 创建BFC */
    background: yellow;
  }
}

在这里插入图片描述


最后

还有其它好的方法,也可以评论一起讨论。👍👍👍

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

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

相关文章

springboot快速整合腾讯云COS对象存储

1、导入相关依赖 <!--腾讯云COS--><dependency><groupId>com.tencentcloudapi</groupId><artifactId>tencentcloud-sdk-java</artifactId><version>3.0.1</version></dependency><dependency><groupId>com…

【C语言】指针---初阶

&#x1f341; 博客主页:江池俊的博客 &#x1f341;收录专栏&#xff1a;C语言——探索高效编程的基石 &#x1f341; 如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏&#x1f31f; 三连支持一下博主&#x1f49e; 目录 一、指针是什么&#xff1f; 1.1指…

FTP服务器无法连接解决办法

FTP服务器无法连接解决办法 目录 一&#xff0e; 报错状态二&#xff0e; 解决办法三&#xff0e; 总结 一&#xff0e; 报错状态 二&#xff0e; 解决办法 &#xff08;确保客户机与服务器可以ping通的情况下&#xff0c;再进行下面操作&#xff09; 检查ftp地址是否输错。默…

Kendo UI,一个加速Web应用界面开发的JavaScript组件库!

Kendo UI是什么&#xff1f; 首先&#xff0c;Kendo UI是一个由四个JavaScript UI库组成的包&#xff0c;这些库是专为jQuery、Angular、React和Vue原生构建的&#xff0c;每一个都是用一致的API和主题构建的。所以无论开发者怎么选择&#xff0c;所开发的Web应用始终保持了现…

QueryWrapper,LambdaQueryWrapper用法简介(MyBatis Plus进阶)

目录 一、项目结构及数据库内容如图二、数据库内容三、代码示例 关于如何使用MyBatis Plus自动生成service&#xff0c;mapper&#xff0c;domain参考我的这篇博客&#x1f449;使用MyBatis Plus自动生成service&#xff0c;mapper&#xff0c;domain 一、项目结构及数据库内容…

使用Docker构建LNMP环境并运行Wordpress网站平台

使用Docker构建LNMP环境并运行Wordpress网站平台 1.基于Dockerfile构建LNMP镜像1.1 基于Dockerfile构建nginx镜像1.1.1 修改/usr/local/nginx/conf/nginx.conf文件1.1.2 再次修改nginx服务的Dockerfile文件&#xff08;多级构建&#xff09;1.1.3 创建安装环境依赖包的镜像 1.2…

系统设计《System Design Interview》读书笔记

设计性能认知 延时 操作名称时间1级缓存引用0.5ns2级缓存引用7ns互斥锁/解锁100ns主存引用100ns用zippy压缩1k字节10,000ns10μs通过1GB网络传输2KB字节20,000ns 20μs内存按照顺序读取1MB250,000ns250μs同一个数据中心内的往返500,000ns 500μs磁盘寻找10,000.000ns10ms从…

Qt - .ui 文件的使用

文章目录 目录工具栏Dock Widget代码控制 ui添加资源添加文件 目录 子目录只能输入英文&#xff0c;想要显示中文&#xff0c;可以修改右下方表中的 text 属性&#xff1a; 工具栏 让工具栏共用 菜单栏的 new 和 open&#xff0c;只需将下方列表的控件&#xff0c;拖拽到工具栏…

解决@Scope(“prototype“)不生效的问题

目录 Scope(“prototype“)不生效Scope(“prototype“)正确用法——解决Bean多例问题 1.问题&#xff0c;Spring管理的某个Bean需要使用多例2.问题升级3. Spring给出的解决问题的办法&#xff08;解决Bean链中某个Bean需要多例的问题&#xff09; Scope(“prototype“)不生效 …

STM32(HAL库)驱动st7789LCD屏幕(7引脚240*240)

目录 1、简介 2、CubeMX初始化配置 2.1 基础配置 2.1.1 SYS配置 2.1.2 RCC配置 2.2 屏幕引脚配置 2.3 项目生成 3、KEIL端程序整合 3.1 LCD驱动添加 3.2 函数修改 3.2.1 lcd.h修改 3.2.2 lcd_innit.h 修改 3.2.3 lcd.c修改 3.2.4 lcd_inut.c修改 3.3 主函数代码 3.3…

VsCode上传到gitee码云仓库详细教程

首先下载git&#xff0c;地址:https://git-scm.com/downloads 1、到你要提交项目的gitee的项目中&#xff0c;右键点击Git Bash Here进入&#xff0c;进入后按顺序输入&#xff1a; 2、第二步输入你的gitee码云账户 输入ssh-keygen -t ed25519 -C "xxxxxxxxxxxxxxxxx&qu…

docker部署应用的三种方式——最后一种直接使用shell脚本一键化部署

docker命令部署 拉取ubuntu的基础镜像 docker pull ubuntu注意基础镜像是压缩版的&#xff0c;只保证能够运行项目的最基础条件&#xff0c;很多命令都是没有的&#xff0c;在使用过程中如果需要那些命令需要提前安装。 安装openjdk sudo apt install openjdk-11-jdk安装mys…

【c++】万字长文,浅析c++继承特性

继承 1. 继承的概念和定义1.1 概念1.2 定义1.2.1 定义格式 2.基类和派生类对象赋值转换&#xff08;##&#xff09;3. 继承中的变量和函数隐藏(#)4.派生类的默认成员函数&#xff08;###&#xff09;5.友元函数和静态成员5.1.友元函数5.2.静态成员 6.菱形继承&#xff08;###&a…

广德上汽通用汽车平行试车场

技术栈&#xff1a;使用vue2JavaScriptElement UIvuexaxioscesium 项目描述&#xff1a;广德上汽通用汽车平行试车场是依托千寻孪界开发的一套展示实时车辆位置同步展示光照&#xff0c;时间&#xff0c;阴影等特效&#xff0c;完成平行时空效果的一款软件。 工作内容&#xff…

Linux 桌面份额突破 3%

导读今天来聊一聊linux桌面。 Linux 桌面份额突破 3% 根据 Statcounter 的数据&#xff0c;Linux 的使用率在过去几年中一直在缓慢上升&#xff0c;趋势非常明显。今年&#xff0c;Linux 桌面的统计数据如下&#xff1a;一月&#xff0c;2.91%&#xff1b;二月&#xff0c;2.9…

基于Python+WaveNet+CTC+Tensorflow智能语音识别与方言分类—深度学习算法应用(含全部工程源码)

目录 前言总体设计系统整体结构图系统流程图 运行环境Python 环境Tensorflow 环境 模块实现1. 方言分类数据下载及预处理模型构建模型训练及保存 2. 语音识别数据预处理模型构建模型训练及保存 3. 模型测试功能选择界面语言识别功能实现界面方言分类功能实现界面 系统测试1. 训…

SpringCloud是SpringBoot 的升级版吗?有什么区别?

目录 一、什么是SpringBoot 二、什么是SpringCloud 三、SpringCloud是SpringBoot 的升级版吗 四、SpringCloud和SpringBoot 有什么区别 一、什么是SpringBoot Spring Boot是一种用于快速构建基于Spring框架的Java应用程序的开发框架。它简化了Spring应用程序的配置和部署过…

超详细图文教程:3DS Max 中创建低多边形游戏长剑模型-下部

推荐&#xff1a; NSDT场景编辑器助你快速搭建可二次开发的3D应用场景 在由两部分组成的教程的第一部分中&#xff0c;我向您展示了如何&#xff1a; 剑柄建模为剑的护手建模剑刃建模 在本教程系列的第二部分中&#xff0c;我将向您展示如何&#xff1a; 打开紫外线包装创建…

【Redis深度专题】「核心技术提升」探究Redis服务启动的过程机制的技术原理和流程分析的指南(基础功能分析)

探究Redis服务启动的过程机制的技术原理和流程分析的指南 Redis基本概念Redis特点说明 Redis源码结构Redis功能架构Redis启动流程初始化全局服务器配置源码分析分析说明initServerConfig方法初始化的内容保存机制的初始化策略优化的初始化策略 指定配置文件加载配置文件默认的数…

【每日运维】RockyLinux8非容器化安装Mysql、Redis、RabitMQ单机环境

系统版本&#xff1a;RockyLinux 8.6 安装方式&#xff1a;非容器化单机部署 安装版本&#xff1a;mysql 8.0.32 redis 6.2.11 rabbitmq 3.11.11 elasticsearch 6.7.1 前置条件&#xff1a;时间同步、关闭selinux、主机名、主机解析host 环境说明&#xff1a;PC电脑VMware Work…