iPhone Mobile Safari似乎缺少element.getBoundingClientRect。 iPhone Mobile Safari上的等效方法是什么?这种方法存在于iPad上。
答案 0 :(得分:8)
编辑1:此代码(webkitConvertPointFromNodeToPage)仅适用于非常旧的和过时的手机...请参阅these comments。
编辑2:我不建议您使用此代码...我记得更改它以处理IE10与触摸缩放的一些问题。我将尽力记住使用修复程序更新代码。
是:我认为以下适用于IE6 +,FF3 +,Safari 2+(桌面和移动),Chrome(桌面和Android),Opera:
function offset(el) {
var convertPoint = window.webkitConvertPointFromNodeToPage;
if ('getBoundingClientRect' in el) {
var
boundingRect = el.getBoundingClientRect(),
body = document.body || document.getElementsByTagName("body")[0],
clientTop = document.documentElement.clientTop || body.clientTop || 0,
clientLeft = document.documentElement.clientLeft || body.clientLeft || 0,
scrollTop = (window.pageYOffset || document.documentElement.scrollTop || body.scrollTop),
scrollLeft = (window.pageXOffset || document.documentElement.scrollLeft || body.scrollLeft);
return {
top: boundingRect.top + scrollTop - clientTop,
left: boundingRect.left + scrollLeft - clientLeft
}
} else if (convertPoint) {
var
zeroPoint = new WebKitPoint(0, 0),
point = convertPoint(el, zeroPoint),
scale = convertPoint(document.getElementById('scalingEl'), zeroPoint);
return {
top: Math.round(point.y * -200/scale.y),
left: Math.round(point.x * -200/scale.x)
}
}
}
以下是身体的孩子:
<div id="scalingEl" style="position:absolute;top:-200px;left:-200px;visibility:hidden;"></div>
方法确实需要一些错误检查(例如,元素必须在文档中)。缩放使其在页面缩放时起作用,但可能不需要(在Windows Safari中测试webkitConvertPointFromNodeToPage时我确实需要它。)
答案 1 :(得分:2)
对于在iOS 3上寻找ele.getBoundingClientRect()。width方法的任何人,你可以使用ele.offsetWidth
if("getBoundingClientRect" in this.container) {
this.width = this.container.getBoundingClientRect().width ;
}else {
this.width = this.container.offsetWidth; //http://help.dottoro.com/ljvmcrrn.php
}