【问题标题】:Cut out shape (triangle) from div and show background behind [closed]从 div 中剪出形状(三角形)并在 [关闭] 后面显示背景
【发布时间】:2013-03-27 13:30:07
【问题描述】:

我正在尝试从 div 中切出一个三角形并显示 div 后面的背景...我不认为这是可能的,但是你们这些专业人士在这里继续让我感到惊讶,所以我认为值得一试:-)

这就是我想要实现的(抱歉图像模糊):

请不要用 3 列解决方案或类似的方法来回答这个问题,我完全有能力以这种方式实现这一点......我只是想知道是否有任何很酷的CSS 技巧可以通过尽可能少的图形(如果不是没有图形)来实现这一点吗?

【问题讨论】:

  • 见问题How does this CSS triangle shape work? 思路是使用一个元素的高宽设置为0,然后使用边框来创建形状。请参阅该问题中的代码示例。
  • 我不是要创建一个三角形!我正在尝试从 div 中切出一个三角形!
  • 如果问题重复,请相应地标记原始问题。答案应该是自包含的。

标签: html css


【解决方案1】:

可以通过一些幻想和一些小技巧来伪造它:

  • 使用border-radius剪掉div的透明角;
  • 使用::before(或::after)伪元素创建一个与div背景色相同的大三角形;
  • 使用z-index将三角形置于背景div上,置于div的内容之下;
  • 使用与你的div大小相同的transparent容器来容纳它,并应用overflow: hidden切割三角形的超出部分;

    等等!

演示http://jsfiddle.net/e2Umv/

不,我不知道这是可能的,我只是喜欢挑战和棘手的问题 :)

HTML

<div class="someText" >
    this text is partially visible;<br/>
    this text is partially visible;<br/>
    this text is partially visible;<br/>
    this text is partially visible;<br/>
    this text is partially visible;<br/>
</div>
<div class="underneathContainer">    
    <div class="cutout">Hello cut out div</div>
</div>

CSS

.someText{    
    background: green;
    position: absolute;
    z-index: 0;    
    top: 0;
}


.underneathContainer{
    margin: 20px;
    width: 260px;
    height: 260px;
    background: rgba(0,0,0,0);    
    overflow: hidden;
}

.cutout{    
    width: 200px;
    height: 200px;    
    background: silver;
    padding: 30px;    
    position: relative;
    z-index: 1;
    border-top-left-radius:30%;    
}
.cutout:before{    
    content: '';
    position: absolute;
    top: -44px;
    left: -30px;
    border-width: 60px 60px 60px 60px;
    border-style: solid;
    border-color: rgba(0,0,0,0) silver silver rgba(0,0,0,0);
    z-index: -1;
}

【讨论】:

  • 为您的努力+1!谢谢,但是你能像我的图片那样在中心有一个三角形吗?
【解决方案2】:

你可以把你的三角形和矩形分开,然后用这样的东西:

<div id="rectangle"><div id="mask"></div></div>



#rectangle{width:300px; height:120px; position:relative; margin-top:100px; background: rgb(30,87,153); /* Old browsers */
/* IE9 SVG, needs conditional override of 'filter' to 'none' */
background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzFlNTc5OSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiM3ZGI5ZTgiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);
background: -moz-linear-gradient(top,  rgba(30,87,153,1) 0%, rgba(125,185,232,1) 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(30,87,153,1)), color-stop(100%,rgba(125,185,232,1))); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(top,  rgba(30,87,153,1) 0%,rgba(125,185,232,1) 100%); /* Chrome10+,Safari5.1+ */
background: -o-linear-gradient(top,  rgba(30,87,153,1) 0%,rgba(125,185,232,1) 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(top,  rgba(30,87,153,1) 0%,rgba(125,185,232,1) 100%); /* IE10+ */
background: linear-gradient(to bottom,  rgba(30,87,153,1) 0%,rgba(125,185,232,1) 100%); /* W3C */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1e5799', endColorstr='#7db9e8',GradientType=0 ); /* IE6-8 */
}

#rectangle:after{content:" "; position:absolute; width:0px; height:0px; top:0; left:100px;border:1px solid white; border-color:transparent white transparent white; border-width:0px 50px 50px 50px;}

#mask{position:absolute; left:0; width:100px; height:50px; background:white;}
#mask:after{position:absolute; content:" "; left:200px; width:100px; background:white; height:50px; }

小提琴here.

【讨论】:

  • 恐怕这不是我要找的,因为它只是创建了一个与后面的背景相同的三角形......我需要三角形是透明的,这样背景才能显示出来不管它是什么。例如,如果后面的背景是一个渐变(确实如此),那么这个渐变将继续穿过三角形......无论如何,谢谢
  • 再次检查:jsfiddle.net/Qs4a8/4
  • 这看起来不错,不过在我接受之前需要对其进行彻底测试......它是否兼容浏览器?非常感谢 +1
  • 只是为了让这更复杂一点......是否可以将三角形的边界从颜色更改为图像?中心矩形的背景也是渐变的,所以边框必须是图片...
  • 我想为该三角形添加边框图像的唯一方法是在三角形后面放置一个带有所需边框的方形 div 并将其旋转 45 度。
【解决方案3】:

我能想到的唯一适用于此的就是image mask。您可能必须将一个元素放在另一个元素之上才能在遮罩上显示内容。

对图像掩码的支持并不普遍(我相信目前只有 webkit),但这可能会随着时间的推移而改变。

【讨论】:

  • 感谢您的回答,不幸的是,这不是我正在寻找的解决方案。我想它不存在,虽然这并不让我感到惊讶...谢谢
猜你喜欢
  • 2017-04-29
  • 2013-12-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-07-03
  • 2015-12-03
  • 1970-01-01
相关资源
最近更新 更多