使用css 画三角形的三种方法

news/2024/12/28 11:38:32/文章来源:https://www.cnblogs.com/milankundea/p/18547893

使用纯css 绘制三角形

方法一 使用边框实现

  1. 先实现一个div 四个粗边框 不同颜色 保留左右和下边框 设置左右边框为颜色为 transparent
<body><div class="div1"></div><div class="div2"></div> <div class="div3"></div><div class="div4"></div></body>
<style>.div1{border-top: 80px solid red;border-right: 80px solid blue;border-bottom: 80px solid yellow;border-left: 80px solid orange;width: 100px;height: 100px;margin-top: 80px;}.div2{border-top: 80px solid red;border-right: 80px solid blue;border-bottom: 80px solid yellow;border-left: 80px solid orange;width: fit-content;margin-top: 80px;}.div3{/* border-top: 80px solid red; */border-right: 80px solid blue;border-bottom: 80px solid yellow;border-left: 80px solid orange;width: fit-content;margin-top: 80px;}.div4{/* border-top: 80px solid red; */border-right: 80px solid transparent;border-bottom: 80px solid yellow;border-left: 80px solid transparent;width: fit-content;margin-top: 80px;}
</style>

方法二 linear-gradient 使用渐变背景

<body><div class="div1"></div><div class="div2"></div> <div class="div3"></div><div class="div4"></div><div class="div5"></div><div class="div6"></div>
</body>
<style>.div1{width: 80px;height: 100px;background-repeat: no-repeat;outline: 1px solid blue;margin-top: 40px;}.div2{width: 80px;height: 100px;background-repeat: no-repeat;outline: 1px solid blue;background-image: linear-gradient(45deg, red 50%, rgba(255, 255, 255, 0) 50%);margin-top: 40px;}.div3{width: 80px;height: 100px;background-repeat: no-repeat;outline: 1px solid blue;background-image: linear-gradient(45deg, red 50%, rgba(255, 255, 255, 0) 50%);background-size: 100% 50%;margin-top: 40px;}.div4{width: 80px;height: 100px;background-repeat: no-repeat;outline: 1px solid blue;background-image: linear-gradient(32deg, red 50%, rgba(255, 255, 255, 0) 50%);background-size: 100% 50%;margin-top: 40px;}.div5{width: 80px;height: 100px;background-repeat: no-repeat;outline: 1px solid blue;background-image: linear-gradient(32deg, orangered 50%, rgba(255, 255, 255, 0) 50%), linear-gradient(148deg, orangered 50%, rgba(255, 255, 255, 0) 50%);background-size: 100% 50%;margin-top: 40px;}.div6{width: 80px;height: 100px;background-repeat: no-repeat;outline: 1px solid blue;background-image: linear-gradient(32deg, orangered 50%, rgba(255, 255, 255, 0) 50%), linear-gradient(148deg, orangered 50%, rgba(255, 255, 255, 0) 50%);background-position: top left, bottom left;background-size: 100% 50%;margin-top: 40px;}
</style>

方法三 clip-path 最精简 但有浏览器兼容问题


<body><div class="div1"></div><div class="div2"></div></body>
<style>.div1{margin: 100px;width: 160px;height: 200px;background-color: yellow;margin-top: 80px;}.div2{margin: 100px;width: 160px;height: 200px;background-color: yellow;clip-path: polygon(0 0, 0% 100%, 100% 50%);margin-top: 80px;}
</style>

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

代码分析工具小结

本文介绍了用于C++代码的分析工具,包括3款静态分析工具和3款动态分析工具。此文总结在平时开发过程中使用到的代码分析工具,分为静态分析和动态分析两个部分,本文只介绍Windows平台的工具。 静态代码分析 CppCheck CppCheck是一款经典的C/C++静态代码检查工具,笔者最开始使…

成为行动上的巨人

总是看到别人的微博,有学习到,有被感到到,有醍醐灌顶到,也有被大开脑洞的时候。今天有了自己的博客,记录学习中的点点滴滴,也希望自己不再是只在知识的边缘磨磨蹭蹭, 而是挖掘进去,进而能够知其然又知其所以然。希望笔记成为自己知识的沉淀和积累,也希望 能够帮助到那…

a-modal打开页面报错Ancestor with aria-hidden

报错信息Blocked aria-hidden on an element because its descendant retained focus. The focus must not be hidden from assistive technology users. Avoid using aria-hidden on a focused element or its ancestor. Consider using the inert attribute instead, which w…

线程状态切换

Java线程控制方法的作用及其区别:start:作用:启动线程,由虚拟机自动调度执行run()方法。 区别:线程处于就绪状态。run:作用:线程逻辑代码块处理,JVM调度执行。 区别:线程处于运行状态。sleep:作用:让当前正在执行的线程休眠(暂停执行)。 区别:不释放锁。wait:作用:…

AI智能检测视频分析网关安全帽检测识别监控解决方案

在当代建筑行业中,保障工人的安全始终是最为紧迫的议题。事故如高空坠落和物体撞击等频繁发生,严重威胁着工人的生命安全。安全帽作为一项基础的个人防护设备,其正确使用对于减轻事故伤害起着至关重要的作用。 不过,依赖传统的人工检查方法不仅效率不高,还可能存在疏漏和错…

制造企业的数字化转型:五款优秀项目管理软件推荐

制造业的生产管理往往涉及复杂的流程和多部门协作,如何确保各环节顺利对接、信息准确传递,是每一家制造企业都在不断优化的问题。面对这些管理难题,越来越多的制造企业引入了项目管理软件,通过直观的任务分配、进度跟踪、数据反馈等功能,极大地提升了生产效率和团队协作质…

React Router 的实现原理

本文分两部分,一说前端路由的基本原理,二说 React Router 的实现原理 前端路由的基本原理​ 不说屁话,从时间线上讲,Web 应用原本是后端渲染,后来随着技术的发展,有了单页面应用,慢慢从后端渲染发展成前端渲染 在博客前端路由hash、history的实现 一问中我已经介绍过这两…

[TJOI2007] 路标设置

[[TJOI2007] 路标设置(https://www.luogu.com.cn/problem/P3853) 题目 B 市和 T 市之间有一条长长的高速公路,公路上相邻路标的最大距离定义为该公路的“空旷指数”。现在公路上增设一些路标,使得公路的“空旷指数”最小。请设计一个程序计算能达到的最小值是多少。请注意,公…

TBM810-ASEMI贴片桥堆8A 1000V

TBM810-ASEMI贴片桥堆8A 1000V编辑:ll TBM810-ASEMI贴片桥堆8A 1000V 型号:TBM810 品牌:ASEMI 封装:TBM-4 特性:贴片桥堆 正向电流:8A 反向耐压:1000V 恢复时间:>2000ns 引脚数量:4 芯片个数:4 芯片尺寸:50MIL 浪涌电流:50A 漏电流:>10uA 工作温度:-55℃~150…

Python开发环境搭建(PyCharm+Anaconda+Git+Gitee)

一、Anaconda介绍 1.1 为什么选择Anaconda? Anaconda是一个开源的Python发行版本,主要用于数据科学和机器学习,它包含了Python、conda以及众多工具和库,让我们可以轻松的构建和管理python虚拟环境,方便的进行python项目开发。下面是选择Anaconda的理由:安装简单方便 便捷…

Visual Studio 快速分析 .NET Dump 文件

前言 在开发和维护 .NET 应用程序的过程中,有时会遇到难以捉摸的性能瓶颈或内存泄漏等问题。这些问题往往发生在生产环境中,难以复现。为了更准确地诊断这些运行时问题,通常会收集应用程序在生产环境中的内存转储文件(.dump 文件)。在这种情况下,分析内存转储文件(.dump…

使用model-viewer加载glb文件

实现效果代码 react项目引入方式可选其一1.在html中引入 <script type="module" src="https://unpkg.com/@google/model-viewer/dist/model-viewer.min.js"></script>npm 或者 yarn安装yarn add @google/model-viewerindex.jsimport React, { …