【腾讯前端面试】纯css画图形

之前参加腾讯面试,第一轮是笔试,面试官发的试卷里有一题手写css画一个扇形、一个平行四边形......笔试时间还是比较充裕的,但是我对这题完全没有思路😭于是就空着了,最后也没过。

今天偶然翻到廖雪峰大佬的博客里提到了关于css画图形的内容:纯CSS气泡效果,瞬间唤起了我尘封的记忆,看了大佬的解法后,我觉得自己又行了👍于是准备接一下这两个还记得的题,在此记录一下。

一. 扇形

画了一个如图的扇形:

由两个元素组成,一个负责画扇形的圆边,一个负责画直线部分。

感觉直线和圆边的衔接处有一条缝,可以稍微调整一下元素尺寸:

二. 平行四边形

画了一个如图的平行四边形:

这个形状需要的线条就比较多了,大概分为下面6条:

我总共用了5个div,每个负责画1~2条线,然后用绝对定位确定每条线的位置,拼成一个完整的平行四边形。代码如下:

html 复制代码
<div style="position: relative;">
	<div style="height: 1px; width: 140px; border-color: #000 transparent transparent transparent; border-style: solid; border-width: 1px; transform: rotate(-45deg); position: absolute; top: 50px; left: -20px;">
</div>
	<div style="border-color: transparent transparent #000 transparent; border-width: 1px; height: 100px; width: 100px; position: absolute; border-style: solid;"></div>
	<div style="height: 1px; width: 140px; border-color: #000 transparent transparent transparent; border-style: solid; border-width: 1px; transform: rotate(-45deg); position: absolute; top: 50px; left: 141px;">
</div>
	<div style="border-color: #000 transparent; border-width: 1px; height: 100px; width: 60px; position: absolute; border-style: solid; left: 100px;"></div>
	<div style="border-color: #000 transparent transparent transparent; border-width: 1px; height: 100px; width: 100px; position: absolute; border-style: solid; left: 159px;"></div>
</div>

可以自己在浏览器里试一下,比如谷歌浏览器可以右键编辑html,替换成上面的代码:

当然这些图形也有其他更简单或者更复杂的形状,我只是选择了我比较喜欢的一种。

动手尝试后感觉还是比较简单的,以后如果再遇到css画简单图形的需求就可以自己做了。

不过在电脑上画可以随时看效果,手写的话,我可能也不能准确无误写出来完全正确的css,只能说写一下拆成几条线,每条线大概的样式设置,比交白卷强。以后面试后还是要把还记得的题多学习一下,也是一个进步的机会💪

相关推荐
uhakadotcom7 分钟前
阿里云Tea OpenAPI:简化Java与阿里云服务交互
后端·面试·github
木木黄木木13 分钟前
css炫酷的3D水波纹文字效果实现详解
前端·css·3d
郁大锤36 分钟前
Flask与 FastAPI 对比:哪个更适合你的 Web 开发?
前端·flask·fastapi
uhakadotcom1 小时前
图像识别中的三大神经网络:Inception、ResNet和VGG
算法·面试·github
uhakadotcom1 小时前
DeepFM算法:提升CTR预估和推荐系统的强大工具
算法·面试·github
HelloRevit1 小时前
React DndKit 实现类似slack 类别、频道拖动调整位置功能
前端·javascript·react.js
ohMyGod_1232 小时前
用React实现一个秒杀倒计时组件
前端·javascript·react.js
uhakadotcom2 小时前
Python 中的 @staticmethod 和 @classmethod 详解
后端·面试·github
eternal__day2 小时前
第三期:深入理解 Spring Web MVC [特殊字符](数据传参+ 特殊字符处理 + 编码问题解析)
java·前端·spring·java-ee·mvc
醋醋2 小时前
Vue2源码记录
前端·vue.js