CSS写三角形、五角形等不规则图形

2024-04-29 23:48

本文主要是介绍CSS写三角形、五角形等不规则图形,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写页面的时候时长遇到一些奇怪图形,用css是可以实现各种不规则图形的,下面举例几个常用的:

一、三角形

利用border-color支持transparent这一特性,隐藏三条边框,实现三角形。

<style>

.triangle {

width: 0;

height: 0;

border-style: solid;

box-sizing: border-box;

border-width: 0 10px 10px;

border-color: transparent transparent #c5c5c5 transparent;

}

</style>

<div class="triangle"></div>

效果如下:

二、左上三角形

<style>

.left-top-triangle {

width: 0;

height: 0;

border-style: solid;

box-sizing: border-box;

border-width: 10px;

border-color: #c5c5c5 transparent transparent #c5c5c5;

}

</style>

<div class="left-top-triangle"></div>

效果如下:

三、正五边形

<style>

.pentagon {

width: 54px;

position: relative;

border-width: 50px 18px 0;

border-style: solid;

border-color: #c5c5c5 transparent;

}

.pentagon::before {

content: "";

position: absolute;

width: 0;

height: 0;

top: -85px;

left: -18px;

border-width: 0 45px 35px;

border-style: solid;

border-color: transparent transparent #c5c5c5;

}

</style>

<div class="pentagon"></div>

效果如下:

气泡框

使用绝对定位进行三角形覆盖,实现气泡框突出部分。

<style>

.bubble-tip {

width: 100px;

height: 30px;

line-height: 30px;

margin-left: 10px;

border: 1px solid #c5c5c5;

border-radius: 4px;

position: relative;

background-color: #fff;

}

.bubble-tip::before {

content: "";

width: 0;

height: 0;

border-style: solid;

border-width: 10px 10px 10px 0;

border-color: transparent #ffffff transparent transparent;

position: absolute;

top: 5px;

left: -10px;

z-index: 2;

}

.bubble-tip::after {

content: "";

width: 0;

height: 0;

border-style: solid;

border-width: 10px 10px 10px 0;

border-color: transparent #c5c5c5 transparent transparent;

position: absolute;

top: 5px;

left: -11px;

z-index: 1;

}

</style>

<div class="bubble-tip"></div>

效果如下:

卡券贴

CSS3当中,background添加了background-size属性,控制背景图片的大小,配合background-position属性,可以在一个背景下面展示多张图片。

卡券贴的核心是使用透明白色径向渐变radial-gradient,分别让4张背景图中的左下角、右下角、右上角和左下角出现缺省,再利用drop-shadow实现元素阴影,从而达到效果。

radial-gradient语法如下:

radial-gradient(shape size at position, start-color, ..., last-color)

描述
shape确定圆的类型:
ellipse (默认): 指定椭圆形的径向渐变。
circle :指定圆形的径向渐变
size定义渐变的大小,可能值:
farthest-corner (默认) : 指定径向渐变的半径长度为从圆心到离圆心最远的角
closest-side :指定径向渐变的半径长度为从圆心到离圆心最近的边
closest-corner : 指定径向渐变的半径长度为从圆心到离圆心最近的角
farthest-side :指定径向渐变的半径长度为从圆心到离圆心最远的边
position定义渐变的位置。可能值:
center(默认):设置中间为径向渐变圆心的纵坐标值。
top:设置顶部为径向渐变圆心的纵坐标值。
bottom:设置底部为径向渐变圆心的纵坐标值。
可混合使用,如top right
start-color, …, last-color用于指定渐变的起止颜色。

<style>

.coupon{

width: 200px;

height: 80px;

background: radial-gradient(circle at right bottom, transparent 10px, #ffffff 0) top right / 50{46ef1d7cfbdffc0db57029f974d30095d18ea60dba1d7b2ffaf442b213727085} 40px no-repeat,

radial-gradient(circle at left bottom, transparent 10px, #ffffff 0) top left / 50{46ef1d7cfbdffc0db57029f974d30095d18ea60dba1d7b2ffaf442b213727085} 40px no-repeat,

radial-gradient(circle at right top, transparent 10px, #ffffff 0) bottom right / 50{46ef1d7cfbdffc0db57029f974d30095d18ea60dba1d7b2ffaf442b213727085} 40px no-repeat,

radial-gradient(circle at left top, transparent 10px, #ffffff 0) bottom left / 50{46ef1d7cfbdffc0db57029f974d30095d18ea60dba1d7b2ffaf442b213727085} 40px no-repeat;

filter: drop-shadow(3px 3px 3px #c5c5c5);

}

</style>

<div class="coupon"></div>

效果如下:

这篇关于CSS写三角形、五角形等不规则图形的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/947477

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

vue监听属性watch的用法及使用场景详解

《vue监听属性watch的用法及使用场景详解》watch是vue中常用的监听器,它主要用于侦听数据的变化,在数据发生变化的时候执行一些操作,:本文主要介绍vue监听属性watch的用法及使用场景... 目录1. 监听属性 watch2. 常规用法3. 监听对象和route变化4. 使用场景附Watch 的

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni