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

相关推荐
梦想是准点下班几秒前
androidStudio打包,我又又又忘了
前端
槑有老呆1 分钟前
栈队列链表,三个故事就懂了
前端
ViavaCos18 分钟前
pnpm v11 的安全策略,让我踩了个坑
前端
To_OC19 分钟前
从一段定时器代码,重新捋清 JS 同步、异步与 Promise
前端·javascript·代码规范
持敬chijing21 分钟前
Web渗透之前后端漏洞-XSS漏洞原理攻击防御全流程
前端·安全·web安全·网络安全·网络攻击模型·安全威胁分析·xss
程序员黑豆28 分钟前
AI全栈开发 - Java:注释
前端·后端·ai编程
痕忆丶37 分钟前
Typora 的替代marktext,marktext切换中文
前端
羊羊小栈1 小时前
Uplift营销供应链协同决策系统(基于Uplift因果推断与运筹优化算法)
前端·人工智能·算法·毕业设计·大作业
阿猫的故乡1 小时前
Vue组合式函数(Composables)从入门到实战:鼠标跟踪、请求封装、本地存储……全案例拆解
前端·vue.js·计算机外设
Upsy-Daisy1 小时前
Hermes Agent 学习笔记 02:安装、配置与第一次运行
java·前端·数据库