CSS_实现三角形和聊天气泡框

如何用css画出一个三角形

1、第一步

写一个正常的盒子模型,先给个正方形的div,便于观察,给div设置宽高和背景颜色

html 复制代码
<body>
    <div class="box"></div>
</body>
<style>
    .box {
         width: 100px;
         height: 100px;
         background-color: pink;
     }
</style>

2、第二步

便于观察,给div设置四个不同颜色的的边框border

html 复制代码
<style>
   .box {
        width: 100px;
        height: 100px;
        background-color: pink;
        border-left: 50px solid skyblue;
        border-right: 50px solid yellow;
        border-bottom: 50px solid yellowgreen;
        border-top: 50px solid violet;
    }
</style>

四种不同颜色的边框,已经可以看出来,四个边框差个尖尖就是三角形

3、第三步

把中间的div的宽高设置为0像素,即可得到四个等腰三角形

html 复制代码
<style>
   .box {
        width: 0px;
        height: 0px;
        background-color: pink;
        border-left: 50px solid skyblue;
        border-right: 50px solid yellow;
        border-bottom: 50px solid yellowgreen;
        border-top: 50px solid violet;
    }
</style>

4、第四步

我们需要哪一边的三角形,把另外三边的边框设置透明transparent即可

比如我现在需要上面的三角形,我就可以把左右下的边框设置透明,并且把div的背景色删掉或者注释掉

html 复制代码
<style>
    .box {
        width: 0px;
        height: 0px;
        /* background-color: pink; */
        border-left: 50px solid transparent;
        border-right: 50px solid transparent;
        border-bottom: 50px solid transparent;
        border-top: 50px solid violet;
    }
</style>

聊天气泡实现

html 复制代码
<body>
    <div class="box"></div>
</body>
<style>
    .box {
        width: 200px;
        height: 100px;
        /*父级给相对定位,伪元素根据父级给绝对定位 */
        position: relative;
        background-color: violet;
        border-radius: 20px;
    }
    
    .box::after {
        content: '';
        width: 0px;
        height: 0px;
        border: 20px solid;
        border-left: 20px solid transparent;
        border-right: 20px solid transparent;
        border-bottom: 20px solid transparent;
        border-top: 20px solid violet;
        /*给绝对定位,根据需求设置三角形的位置*/
        position: absolute;
        top: 100px;
        left: 50px;
    }
</style>

简单代码实现

html 复制代码
<div class="wrapper"></div>
<style>
	.wrapper {
		position: relative;
		width: 200px;
		height: 200px;
		margin: 50px auto;
		border-radius: 12px;
		background: #ffffff;
		filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.3));
		padding: 20px;
	}
	.wrapper:before {
		content: "";
		position: absolute;
		width: 0;
		height: 0;
		border: 10px solid transparent;
		border-bottom-color: #ffffff;
		top: -20px;
		left: 50px;
	}
</style>
相关推荐
带着梦想扬帆启航3 小时前
UniApp 多个异步开关控制教程
前端·javascript·uni-app
小高0073 小时前
JavaScript 内存管理是如何工作的?
前端·javascript
是大林的林吖3 小时前
解决 elementui el-cascader组件懒加载时存在选中状态丢失的问题?
前端·javascript·elementui
鹏仔工作室3 小时前
elemetui中el-date-picker限制开始结束日期只能选择当月
前端·vue.js·elementui
一 乐3 小时前
个人博客|博客app|基于Springboot+微信小程序的个人博客app系统设计与实现(源码+数据库+文档)
java·前端·数据库·spring boot·后端·小程序·论文
sTone873753 小时前
Android Room部件协同使用
android·前端
晴殇i3 小时前
前端代码规范体系建设与团队落地实践
前端·javascript·面试
用户74054639943093 小时前
Vite 库模式输出 ESM 格式时的依赖处理方案
前端·vite
开发者小天3 小时前
React中使用useParams
前端·javascript·react.js
lichong9513 小时前
Android studio release 包打包配置 build.gradle
android·前端·ide·flutter·android studio·大前端·大前端++