html中如何写不规则图形,CSS写三角形、五角形等不规则图形

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

一、三角形

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

.triangle {

width: 0;

height: 0;

border-style: solid;

box-sizing: border-box;

border-width: 0 10px 10px;

border-color: transparent transparent #c5c5c5 transparent;

}

效果如下:

5347cd5bb3232b4fbc56831ced07ba1d.png

二、左上三角形

.left-top-triangle {

width: 0;

height: 0;

border-style: solid;

box-sizing: border-box;

border-width: 10px;

border-color: #c5c5c5 transparent transparent #c5c5c5;

}

效果如下:

1db8b53ba33f1bfcaf3c181f466546ea.png

三、正五边形

.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;

}

效果如下:

519b2b0b5398d92792ff4dfe8f4d3f5b.png

气泡框

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

.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;

}

效果如下:

be9fa947198748dcf5265263b855f3ff.png

卡券贴

在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用于指定渐变的起止颜色。

.coupon{

width: 200px;

height: 80px;

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

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

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

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

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

}

效果如下:

21842410a3a71221e8e2d152a49f1579.png

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 使用CSS绘制三角形的方法之一是使用"border"属性。 例如:div { width: 0; height: 0; border-left: 20px solid transparent; border-right: 20px solid transparent; border-bottom: 30px solid red; } ### 回答2: 要用CSS出一个三角形,可以通过调整元素的宽度、高度和边框来实现。 一个常用的方法是使用边框来画出三角形。 首先,创建一个具有零宽度和高度的`div`元素,并设置其边框的颜色和样式。例如: ```css .triangle { width: 0; height: 0; border-left: 50px solid transparent; //设置左侧边框颜色为透明 border-right: 50px solid transparent; //设置右侧边框颜色为透明 border-bottom: 50px solid red; //设置底部边框颜色为红色 } ``` 在这个例子,设置了一个宽度和高度为零的`div`元素,并通过设置边框的颜色和样式来画出一个红色的三角形。 你可以根据需要,调整`width`、`height`和边框的颜色和样式来得到不同形状和颜色的三角形。 此外,还有其他通过旋转或使用伪元素`before`和`after`等方式来实现三角形的方法,但使用边框是最常见和简单的方法之一。 通过以上的CSS代码,你可以在HTML使用`<div class="triangle"></div>`来创建一个三角形,然后根据需要在页面上进行样式调整。 ### 回答3: 要用CSS出一个三角形,可以使用CSS的border属性来实现。下面是一个简单的方法: 1. 创建一个元素,可以是div、span或其他块级或内联元素。 2. 设置元素的宽度和高度为0像素。 3. 设置元素的边框样式和颜色。 4. 使用border-width属性设置三角形的大小。将左边和右边边框的宽度设置为0,将下边边框的宽度设置为三角形的高度,例如10像素。 5. 设置边框的颜色和样式。 6. 通过旋转元素来调整三角形的方向。可以使用transform属性的rotate()函数,例如rotate(45deg),将元素以45度的角度顺时针旋转。 示例代码如下: ``` <style> .triangle { width: 0; height: 0; border-style: solid; border-width: 0 10px 10px 10px; /* 上、右、下、左 */ border-color: transparent transparent #000 transparent; /* 上、右、下、左 */ transform: rotate(45deg); } </style> <div class="triangle"></div> ``` 在这个示例,通过设置border-width属性的四个参数来定义三角形的大小和形状。通过设置border-color属性来定义边框的颜色,其左边和右边的颜色设置为透明,使得只有底边的颜色是可见的。通过transform属性的rotate()函数来旋转元素,使得三角形以45度的角度旋转。 通过调整border-width的参数值、border-color的颜色值,以及transform的旋转角度,可以根据需要来调整三角形的样式和形状。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值