11

我一直在为这个问题扯掉我的头发,我想要一个围绕整个元素的简单阴影,除了顶部。我让它在 Firefox 和 Chrome 中运行没有问题。但是 IE 有这个奇怪的“方向”设置,其中另一个是 4 个数字来定义阴影。

有人可以帮我定义正确的 CSS,以便它在除顶部之外的整个元素周围有阴影。

/* For Firefox and Chrome */
-moz-box-shadow: 0px 0px 7px #000;
-webkit-box-shadow: 0px 0px 7px #000;
 box-shadow: 0px 0px 7px #000;

 /* for IE */
 -ms-filter: "progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=600, Color='#000000')";
4

4 回答 4

24

阴影滤镜是单向的,方向是 1 到 360 度之间的数字。要生成能够抵消该阴影的盒子阴影,您需要使用多个阴影过滤器:

   filter: progid:DXImageTransform.Microsoft.Shadow(Color=#cccccc, Strength=5, Direction=0),
     progid:DXImageTransform.Microsoft.Shadow(Color=#cccccc, Strength=5, Direction=90),
     progid:DXImageTransform.Microsoft.Shadow(Color=#cccccc, Strength=5, Direction=180),
     progid:DXImageTransform.Microsoft.Shadow(Color=#cccccc, Strength=5, Direction=270);

这是按上/右/下/左排序的,改变任何一侧的强度都会改变阴影的大小。例如,2 5 5 10 将产生一个直下的阴影,给人一种高度的错觉。

于 2011-10-20T19:24:17.100 回答
8

类似于上面的答案(见下面的注释):

#boxContainer{ 
   filter:
        progid:DXImageTransform.Microsoft.Shadow(Strength=3, Direction=0, Color='#000000'),
        progid:DXImageTransform.Microsoft.Shadow(Strength=3, Direction=90, Color='#000000'),
        progid:DXImageTransform.Microsoft.Shadow(Strength=3, Direction=180, Color='#000000'),
        progid:DXImageTransform.Microsoft.Shadow(Strength=3, Direction=270, Color='#000000');
}

重要提示: 请记住,IE 中还有一个错误,它会将相同的样式应用于子元素。因此,如果您愿意,您可能需要应用“计数器”/“Nullifier”。

例子:

#boxContainer button, #boxContainer div, #boxContainer span {
  /* Nullify Inherited Effect - Set "Strength=0" */
  filter:
    progid:DXImageTransform.Microsoft.Shadow(Strength=0, Direction=0, Color='#000000'),
    progid:DXImageTransform.Microsoft.Shadow(Strength=0, Direction=90, Color='#000000'),
    progid:DXImageTransform.Microsoft.Shadow(Strength=0, Direction=180, Color='#000000'),
    progid:DXImageTransform.Microsoft.Shadow(Strength=0, Direction=270, Color='#000000');
}
于 2012-10-02T05:14:11.907 回答
5

尝试使用“发光”过滤器:

http://msdn.microsoft.com/en-us/library/ms532995(v=VS.85).aspx

 DIV.aFilter {
    filter:progid:DXImageTransform.Microsoft.Glow(Color=blue,Strength=5);
    width: 150px;}
于 2011-10-20T19:17:18.927 回答
0

这里有解决方案: http ://www.artlebedev.com/tools/technogrette/html/filters-in-ie/ 结合看起来明显更好的发光和模糊过滤器,引用上面页面上的代码示例之一:

.shadowed .shadow-3
{
filter: progid:DXImageTransform.Microsoft.Glow(Color=#000000,Strength=1.0)
progid:DXImageTransform.Microsoft.Alpha(opacity=25)
progid:DXImageTransform.Microsoft.Blur(pixelradius=1.75, enabled='true');
-ms-filter: "progid:DXImageTransform.Microsoft.Glow(Color=#000000,Strength=1.0)"
"progid:DXImageTransform.Microsoft.Alpha(opacity=25)"
"progid:DXImageTransform.Microsoft.Blur(pixelradius=1.75, enabled='true')";
color: #111111;
top: -2px;
left: -2px;
}
于 2016-08-11T11:48:30.677 回答