首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将“div”形状为带有CSS的标志

如何将“div”形状为带有CSS的标志
EN

Stack Overflow用户
提问于 2015-03-08 21:25:36
回答 7查看 10.9K关注 0票数 8

我想添加一个标签在我的一些元素在一个网站和设计的标签,是一个旗帜与倒置的V形削减在底部。

到目前为止我有这样的想法:

HTML

代码语言:javascript
复制
<div class="css-shapes"></div>

CSS

代码语言:javascript
复制
.css-shapes{
    border-left: 99px solid #f00fff;
    border-right: 99px solid #f00fff;
    border-bottom: 39px solid transparent;
}

http://jsfiddle.net/yhexkm4u/2/

然而,我需要的背景是白色和边框在这个形状的紫色和1 1px。我试着在这个里面装上同样的形状,但是一切都变得很混乱,没有像预期的那样进行。

也许这是一种错误的方法,但我想最终得到这样的标签:

EN

回答 7

Stack Overflow用户

回答已采纳

发布于 2015-03-09 00:34:35

下面是一种稍微不同的方法,使用伪元素转换旋转来创建一个概述的横幅,如下所示:

  • 这个角形是用position: absolute伪元素、:before:after创建的。

  • 在父级上用overflow: hidden切断多余的部分,形成我们的横幅:

  • 轮廓是用box-shadow创建的,通过用46px - box-shadow: 46px 0 0 3px #000拉/推x轴来防止两个角度重叠。

全例

代码语言:javascript
复制
div {
  height: 100px;
  width: 100px;
  margin: 100px auto;
  position: relative;
  overflow: hidden;
  border: solid 3px #000;
  border-bottom: none;
  text-align: center;
}
div:before,
div:after {
  content: '';
  display: block;
  height: 100%;
  width: 200%;
  transform: rotate(20deg);
  box-shadow: 46px 0 0 3px #000;
  position: absolute;
  top: 1px;
  right: -120%;
}
div:after {
  transform: rotate(-20deg);
  left: -120%;
  box-shadow: -46px 0 0 3px #000;
}
代码语言:javascript
复制
<div>Text</div>

票数 8
EN

Stack Overflow用户

发布于 2015-11-19 11:31:20

带有CSS的

您可以在伪元素上使用CSS变换创建背景,在底部有一个透明的倒三角形

代码语言:javascript
复制
body{background:url('http://lorempixel.com/image_output/food-q-c-640-480-1.jpg');background-size:cover;}
p{
  position: relative;
  width: 150px; height: 150px;
  overflow: hidden;
  border-top:3px solid #EF0EFE;
}
p:before, p:after{
  content: '';
  position: absolute;
  top: -3px;
  height: 100%; width: 50%;
  z-index: -1;
  border:2px solid #EF0EFE;
  box-sizing:border-box;
}
p:before{
  left: 0;  
  transform-origin: 0 0;
  transform: skewY(-20deg);
  border-width:0 0 4px 3px;
}
p:after{
  right: 0;
  transform-origin: 100% 0;
  transform: skewY(20deg);
  border-width:0 3px 4px 0;
}
代码语言:javascript
复制
<p>Some text ... </p>

请注意,您需要在transformtransform-origin属性上添加供应商前缀,以最大限度地提高浏览器支持。有关详细信息,请参阅http://caniuse.com/#feat=transforms2d

与SVG

另一种方法是在多边形元素中使用内插SVG

代码语言:javascript
复制
body{background: url('http://lorempixel.com/image_output/food-q-c-640-480-1.jpg');background-size: cover;}
div{position: relative;width: 100px; height: 150px;}
svg{position: absolute;width: 100%;height: 100%;z-index: -1;}
代码语言:javascript
复制
<div>
  <svg viewbox="-1.5 -1.5 103 153">
    <polygon points="100 0, 100 100, 50 85, 0 100, 0 0" fill="transparent" stroke-width="3" stroke="#ef0efe"/>
  </svg>
  <p>Some text ... </p>
</div>

票数 11
EN

Stack Overflow用户

发布于 2015-03-09 00:05:41

从CSS中窃取-形状

代码语言:javascript
复制
#flag {
  width: 110px;
  height: 56px;
  padding-top: 15px;
  position: relative;
  background: red;
  color: white;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-align: center;
  text-transform: uppercase;
}
#flag:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 0;
  border-bottom: 13px solid #eee;
  border-left: 55px solid transparent;
  border-right: 55px solid transparent;
}

演示:

代码语言:javascript
复制
#flag {
  width: 110px;
  height: 56px;
  padding-top: 15px;
  position: relative;
  background: red;
  color: white;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-align: center;
  text-transform: uppercase;
}
#flag:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 0;
  border-bottom: 13px solid #eee;
  border-left: 55px solid transparent;
  border-right: 55px solid transparent;
}
代码语言:javascript
复制
<div id="flag"></div>

我的方法

我的方法使用了扭曲的元素,并允许您快速地将它们定位到您的需要。

代码语言:javascript
复制
div {
  height: 100px;
  width: 100px;
  position: relative;
  border-left: 10px solid tomato;
  border-top: 10px solid tomato;
  border-right: 10px solid tomato;
  text-align: center;
  line-height: 100px;
  font-size: 30px;
}
div:before {
  content: "";
  position: absolute;
  height: 50%;
  width: 50%;
  left: -10px; /*width of border*/
  bottom: -30px;
  z-index: -2;
  -webkit-transform: skewY(-20deg);
  transform: skewY(-20deg);
  border-bottom: 10px solid tomato;
  border-left: 10px solid tomato;
}
div:after {
  content: "";
  position: absolute;
  height: 50%;
  width: 50%;
  right: -10px; /*width of border*/
  bottom: -30px;
  z-index: -2;
  -webkit-transform: skewY(20deg);
  transform: skewY(20deg);
  border-bottom: 10px solid tomato;
  border-right: 10px solid tomato;
}
div:hover, div:hover:before, div:hover:after{
  background:lightgray;
  }
代码语言:javascript
复制
<div>TEXT</div>

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28932080

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档