javascript – 如何解决Safari错误,即使隐藏溢出,也允许过滤器
我正在尝试使用CSS过滤器来模糊图像.在所有浏览器中,模糊滤镜会导致模糊超出图像范围,无论您将模糊设置为(预期)的值.但是我想要定义边缘(并且图像有一个盒子阴影),所以我用另一个div设置图像将其设置为隐藏.这适用于所有浏览器. 但是,由于某些特定于应用程序的约束,我需要在加载时使用JavaScript更新包装器的大小并调整大小.这适用于除Safari之外的所有浏览器.随机更改包装元素的大小会触发绘制错误,其中过滤器开始越过包装器的边界.它并不总是如此,但似乎在MobileSafari上和/或基于DOM的大小增加了可能性. Here’s a fiddle带小演示.使用Safari,重复调整窗口大小,您将触发错误.有时它会重新粉碎并自我修复,有时它不会. (使用Chrome或Firefox,它会正常工作.) (Screenshot of the blur escaping the wrapper.) 应该注意的是,与这个小提琴不同,在应用程序中我只是在它们改变时设置新的宽度和高度,并且即使在调整大小事件期间没有设置宽度和高度,Safari仍然在模糊转义和不转义之间波动. . 我尝试过的事情(没有奏效): >使用clearTimeout / setTimeout延迟包装器宽度的计算和设置,直到resize事件完成 我现在很困惑,非常感谢你提供的任何帮助.谢谢! 最佳答案
你可以在CSS中为你的包装器提供一个流畅的宽度,它与你现在的JS代码具有相同的效果,这可能会修复你的bug,你也可以将img的宽度改为max-width
|