【腾讯前端面试】纯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,只能说写一下拆成几条线,每条线大概的样式设置,比交白卷强。以后面试后还是要把还记得的题多学习一下,也是一个进步的机会💪

相关推荐
合作小小程序员小小店5 小时前
web开发,在线%超市销售%管理系统,基于idea,html,jsp,java,ssh,sql server数据库。
java·前端·sqlserver·ssh·intellij-idea
不爱学英文的码字机器6 小时前
重塑 Web 性能:用 Rust 与 WASM 构建“零开销”图像处理器
前端·rust·wasm
浩星6 小时前
react的框架UmiJs(五米)
前端·javascript·react.js
子醉8 小时前
推荐一种适合前端开发使用的解决本地跨域问题的办法
前端
Niyy_8 小时前
前端一个工程构建多个项目,记录一次工程搭建
前端·javascript
xiangxiongfly9159 小时前
CSS link标签
前端·css
岁月宁静10 小时前
AI 多模态全栈应用项目描述
前端·vue.js·node.js
十年磨一剑~10 小时前
html+js开发一个测试工具
javascript·css·html
爱吃巧克力的程序媛10 小时前
将qt界面中加载css或者qss样式
开发语言·css·qt