使用 css 创建的三角形的框阴影
Box shadow to triangle created using css
我有以下 plunker,其中我使用 CSS.
创建了一个三角形
CSS:
.triangle {
border: inset 6px;
content: "";
display: block;
height: 0;
width: 0;
border-color: transparent transparent red transparent;
border-bottom-style: solid;
position: absolute;
top: 50px;
left: 50px;
z-index: 89;
}
HTML:
<div class="triangle">
</div>
在我的 AngularJS 项目中,这个三角形是在我调用定义的下拉指令时创建的 here.
问题是我想给这个三角形和下拉弹出框一个框阴影。我可以将它应用于弹出窗口(本质上只是一个 'ul' 列表),但我正在努力处理三角形。如何将方框阴影应用于三角形?
.triangle {
position: relative;
margin: 0;
box-sizing: border-box;
background: red;
box-shadow: 0px 3px 3px 0 rgba(0, 0, 0, 0.4);
}
.triangle::after {
content: "";
position: absolute;
top: 50px;
left: 50px;
width: 0;
height: 0;
box-sizing: border-box;
border: 6px solid black;
border-color: transparent transparent red red;
transform-origin: 0 0;
transform: rotate(-45deg);
box-shadow: -3px 3px 3px 0 rgba(0, 0, 0, 0.4);
}
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="style.css">
<script src="script.js"></script>
</head>
<body>
<div class="triangle">
</div>
</body>
</html>
这里是 HTML 和 CSS 以创建所需的效果。
由于三角形实际上是一个 hack(块元素的四个边框中的三个是透明的),box-shadow 属性 不会按预期工作,因为它仍然可以看到您要查看的元素将此 'hack' 应用为矩形,因此相应地应用框阴影。
结果在this fiddle.
.triangle:before {
border: inset 6px;
content: "";
display: block;
height: 0;
width: 0;
border-color: transparent transparent red transparent;
border-bottom-style: solid;
position: absolute;
top: 50px;
left: 50px;
z-index: 89;
box-shadow: 0px 0px 2px 2px #AAA;
}
<div class="triangle">
</div>
我有以下 plunker,其中我使用 CSS.
创建了一个三角形CSS:
.triangle {
border: inset 6px;
content: "";
display: block;
height: 0;
width: 0;
border-color: transparent transparent red transparent;
border-bottom-style: solid;
position: absolute;
top: 50px;
left: 50px;
z-index: 89;
}
HTML:
<div class="triangle">
</div>
在我的 AngularJS 项目中,这个三角形是在我调用定义的下拉指令时创建的 here.
问题是我想给这个三角形和下拉弹出框一个框阴影。我可以将它应用于弹出窗口(本质上只是一个 'ul' 列表),但我正在努力处理三角形。如何将方框阴影应用于三角形?
.triangle {
position: relative;
margin: 0;
box-sizing: border-box;
background: red;
box-shadow: 0px 3px 3px 0 rgba(0, 0, 0, 0.4);
}
.triangle::after {
content: "";
position: absolute;
top: 50px;
left: 50px;
width: 0;
height: 0;
box-sizing: border-box;
border: 6px solid black;
border-color: transparent transparent red red;
transform-origin: 0 0;
transform: rotate(-45deg);
box-shadow: -3px 3px 3px 0 rgba(0, 0, 0, 0.4);
}
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="style.css">
<script src="script.js"></script>
</head>
<body>
<div class="triangle">
</div>
</body>
</html>
这里是 HTML 和 CSS 以创建所需的效果。
由于三角形实际上是一个 hack(块元素的四个边框中的三个是透明的),box-shadow 属性 不会按预期工作,因为它仍然可以看到您要查看的元素将此 'hack' 应用为矩形,因此相应地应用框阴影。
结果在this fiddle.
.triangle:before {
border: inset 6px;
content: "";
display: block;
height: 0;
width: 0;
border-color: transparent transparent red transparent;
border-bottom-style: solid;
position: absolute;
top: 50px;
left: 50px;
z-index: 89;
box-shadow: 0px 0px 2px 2px #AAA;
}
<div class="triangle">
</div>