我有一个缩放背景图像以适合其容器,并且当 Modernizr 检测到浏览器不支持背景大小时,我有适当的后备(未显示)。
.wrap {
width: 200px;
height: 116px;
position: absolute;
background-image: url(image.jpg);
background-attachment: fixed;
background-position: 0 0;
background-size: 200px 116px;
background-repeat: no-repeat;
}
这是一个例子:http: //jsfiddle.net/crowjonah/6xYNm/
它在 Chrome、Firefox、Safari(桌面和 iOS)中看起来很漂亮,但是我在某些 Android 实例上遇到了问题。
这是正确显示的设备的 UA:
Mozilla/5.0 (Linux; U; Android 4.0.4; en-us; Xoom Build/IMM76L) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Safari/534.30
这是一个不支持的设备的 UA:
Mozilla/5.0 (Linux; U; Android 4.2.2; en-us; sdk Build/JB_MR1.1) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Mobile Safari/534.30
较新版本的 Android(模拟)将固定的背景图像缩放为全部爆炸和像素化以适应(我认为)视口,并且不注意其容器的大小或定义的background-size
.
这一切都很好。事实上,这就是MDN 所说的将会发生的事情:
如果背景的附件是固定的,则背景定位区域是浏览器窗口的整个区域,不包括滚动条覆盖的区域(如果存在)。
我的问题是我不知道如何合理地检测何时会或不会出现这种情况,以便我可以相应地进行调整。由于页面上的布局和动画,我真的希望为所有支持它的浏览器修复背景,并且scroll
如果我能弄清楚如何定位它,就可以解决这种极端情况。
更新(2013 年 10 月 3 日): 为了防止混淆,我更新了小提琴以演示一个更现实和有问题的示例,该示例证明了我定义的更多 CSS 属性:http: //jsfiddle.net/crowjonah /QtpVN/