我正在尝试使用CSS过滤器来模糊图像.在所有浏览器中,模糊滤镜会导致模糊超出图像范围,无论您将模糊设置为(预期)的值.但是我想要定义边缘(并且图像有一个盒子阴影),所以我用另一个div设置图像将其设置为隐藏.这适用于所有浏览器.
但是,由于某些特定于应用程序的约束,我需要在加载时使用JavaScript更新包装器的大小并调整大小.这适用于除Safari之外的所有浏览器.随机更改包装元素的大小会触发绘制错误,其中过滤器开始越过包装器的边界.它并不总是如此,但似乎在MobileSafari上和/或基于DOM的大小增加了可能性.
Here’s a fiddle带小演示.使用Safari,重复调整窗口大小,您将触发错误.有时它会重新粉碎并自我修复,有时它不会. (使用Chrome或Firefox,它会正常工作.)
(Screenshot of the blur escaping the wrapper.)
应该注意的是,与这个小提琴不同,在应用程序中我只是在它们改变时设置新的宽度和高度,并且即使在调整大小事件期间没有设置宽度和高度,Safari仍然在模糊转义和不转义之间波动. .
我尝试过的事情(没有奏效):
>使用clearTimeout / setTimeout延迟包装器宽度的计算和设置,直到resize事件完成
>取消设置和重置溢出:在更改大小后,使用JavaScript在包装器和图像上隐藏
>调用window.getComputedStyle(包装器)(并在图像上和父元素上)
>各种各样的恶作剧将包装器推广到复合元素(例如translateZ(0)变换),这确实会阻止一些模糊溢出,但还不够. (Screenshot.)设置计时器以禁用变换只会将页面返回到完全模糊转义.
>设置白色空间:nowrap在包装器上
>通过document.styleSheets [x] .cssRules [x] .style.setProperty()而不是object.style.width / height设置宽度和高度
>将像素值舍入为2/5/10的倍数(是的,我很绝望)
我现在很困惑,非常感谢你提供的任何帮助.谢谢!