有没有办法让阴影只落在底部?我有一个菜单,两个图像彼此相邻。我不想要一个正确的阴影,因为它重叠了正确的图像。我不喜欢使用图像,所以有没有一种方法只把它放在底部,比如:

box-shadow-bottom: 10px #FFF;或类似的吗?

-moz-box-shadow: 0px 3px 3px #000;
-webkit-box-shadow: 0px 3px 3px #000;
box-shadow-bottom: 5px #000;
/* For IE 8 */
-ms-filter: "progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=180, Color='#000000')";
/* For IE 5.5 - 7 */
filter: progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=180, Color='#000000');

当前回答

如果你的背景是实心的(或者你可以使用CSS重现它),你可以这样使用线性渐变:

div { 背景-图像:线性梯度(到顶部,rgba(0,0,0,0) 0%, rgba(0,0,0,0.3) 5px, #fff 5px, #fff 100%) } < div > < p > Foobar < / p > < p > < / p >测试 < / div >

这将在元素底部生成5px的渐变,从不透明度30%的黑色到完全透明。元素的其余部分为白色背景。当然,改变线性渐变的最后2个色点,你可以使背景完全透明。

其他回答

你可以这样做:

一般的语法:

selector {
   box-shadow: topBoxShadow, bottomBoxShadow, rightBoxShadow, leftBoxShadow
}

示例:我们只想创建一个红色的底框阴影,

因此,为了做到这一点,我们必须设置所有的边选项,我们必须设置底部框的阴影选项,并将所有其他选项设置为空,如下所示:

.box {
     -moz-box-shadow: 0 0 0 transparent ,0 0 10px red, 0 0 0 transparent, 0 0 0 transparent
     -o-box-shadow: 0 0 0 transparent ,0 0 10px red, 0 0 0 transparent, 0 0 0 transparent
     -webkit-box-shadow: 0 0 0 transparent ,0 0 10px red, 0 0 0 transparent, 0 0 0 transparent
     box-shadow: 0 0 0 transparent ,0 0 10px red, 0 0 0 transparent, 0 0 0 transparent
}

另一个想法是基于@theengineear的回答,我将使用inset而不是polygon。它更容易,因为它的工作方式与边距或填充相同。我还将依靠CSS变量来轻松定义所有不同的情况。

.shadow { box-shadow: 0 0 8px 5px rgba(200, 0, 0, 0.5); clip-path:inset(var(--t,0) var(--r,0) var(--b,0) var(--l,0)) } .top { --t:-100%; } .right { --r:-100%;} .bottom { --b:-100%; } .left { --l:-100%;} /* layout for example */ .box { display: inline-block; vertical-align: top; background: #338484; color: #fff; width: 4em; height: 2em; margin: 1em; padding: 1em; } <div class="box">none</div> <div class="box shadow top right left bottom">all</div> <div class="box shadow top">top</div> <div class="box shadow right">right</div> <div class="box shadow bottom">bottom</div> <div class="box shadow left">left</div> <div class="box shadow bottom right">bottom right</div> <div class="box shadow bottom top">top bottom</div> <div class="box shadow left top right">top left right</div> <div class="box shadow left right"> left right</div>

内阴影

.shadow { -webkit-box-shadow: inset 00 9px #000; -moz-box-shadow: inset 00 9px #000; 盒子阴影:插入00 9px #000; } < div class = "影子”> wefwefwef < / div >

更新4

与更新3相同,但使用了现代css(=更少的规则),因此不需要在pseudo元素上进行特殊定位。

#箱{ background - color: # 3 d6aa2; 宽度:160 px; 身高:90 px; 位置:绝对的; 顶部:calc(10% - 10px); 左:calc(50% - 80px); } .box-shadow:{后 内容:“”; 位置:绝对的; 宽度:100%; 底部:1 px; z - index: 1; 变换:规模(。9); Box-shadow: 0px 0px 8px 2px #000000; } <div id="box" class="box-shadow"></div>

更新3

我之前所有的回答都是使用额外的标记来创建这种效果,这是不必要的。我认为这是一个更干净的解决方案……唯一的技巧是处理这些值,以获得正确的阴影位置以及正确的阴影强度/不透明度。这是一个新的小提琴,使用伪元素:

http://jsfiddle.net/UnsungHero97/ARRRZ/2/

HTML

<div id="box" class="box-shadow"></div>

CSS

#box {
    background-color: #3D6AA2;
    width: 160px;
    height: 90px;
    margin-top: -45px;
    margin-left: -80px;
    position: absolute;
    top: 50%;
    left: 50%;
}

.box-shadow:after {
    content: "";
    width: 150px;
    height: 1px;
    margin-top: 88px;
    margin-left: -75px;
    display: block;
    position: absolute;
    left: 50%;
    z-index: -1;
    -webkit-box-shadow: 0px 0px 8px 2px #000000;
       -moz-box-shadow: 0px 0px 8px 2px #000000;
            box-shadow: 0px 0px 8px 2px #000000;
}

更新2

显然,你可以像其他人指出的那样,只需要一个额外的参数就可以做到这一点。下面是演示:

http://jsfiddle.net/K88H9/821/

CSS

-webkit-box-shadow: 0 4px 4px -2px #000000;
   -moz-box-shadow: 0 4px 4px -2px #000000;
        box-shadow: 0 4px 4px -2px #000000;

这将是一个更好的解决方案。添加的额外参数描述为:

第四个长度是一个扩展 距离。正值导致 阴影形状全部展开 指定半径的方向。 负值会产生阴影形状 合同。

更新

在jsFiddle: http://jsfiddle.net/K88H9/4/上查看演示

我所做的是创建一个“阴影元素”,它会隐藏在你想要有阴影的实际元素后面。我使“阴影元素”的宽度正好小于实际元素的宽度2倍您指定的阴影;然后我把它对齐。

HTML

<div id="wrapper">
    <div id="element"></div>
    <div id="shadow"></div>
</div>

CSS

#wrapper {
    width: 84px;
    position: relative;
}
#element {
    background-color: #3D668F;
    height: 54px;
    width: 100%;
    position: relative;
    z-index: 10;
}
#shadow {
    background-color: #3D668F;
    height: 8px;
    width: 80px;
    margin-left: -40px;
    position: absolute;
    bottom: 0px;
    left: 50%;
    z-index: 5;
    -webkit-box-shadow: 0px 2px 4px #000000;
       -moz-box-shadow: 0px 2px 4px #000000;
            box-shadow: 0px 2px 4px #000000;
}

原来的答案

是的,您可以使用您提供的相同语法完成此操作。第一个值控制水平定位,第二个值控制垂直定位。所以只需要设置第一个值为0px,第二个值为你想要的偏移量,如下所示:

-webkit-box-shadow: 0px 5px #000000;
   -moz-box-shadow: 0px 5px #000000;
        box-shadow: 0px 5px #000000;

要了解更多关于框阴影的信息,请查看这些:

http://www.css3.info/preview/box-shadow/ https://developer.mozilla.org/en/css/-moz-box-shadow#Browser_compatibility http://www.w3.org/TR/css3-background/#the-box-shadow

如何只是使用一个包含div溢出设置为隐藏和一些填充在底部?这似乎是最简单的解决方案。

很抱歉,我自己没有想到这一点,但在其他地方看到了。

使用一个元素来包装元素,获得box-shadow和overflow:隐藏在包装中,您可以使额外的box-shadow消失,仍然有可用的边界。 这也解决了元素看起来较小的问题,因为扩散。 是这样的: #包装{填充底部:10px;溢出:隐藏;} #elem {box-shadow: 0 0 10px黑色;} 内容在这里 当它必须在纯CSS中完成时,仍然是一个聪明的解决方案!

正如Jorgen Evens所说。