Ajax 板


LINE

看原始码,jQuery.fn.offset函式内的部份程式为: box = elem.getBoundingClientRect(); clientTop = docElem.clientTop || body.clientTop || 0; scrollTop = win.pageYOffset || docElem.scrollTop; top = box.top + scrollTop - clientTop; 因为卷轴在视窗左边或顶端时要减去,所以减去clientTop,这个没问题。 但当docElem.clientTop为0,body.clientTop不为0时,问题就出现了。 因为docElem.clientTop为0,判断为伪,所以clientTop = body.clientTop。 这时设个 $(body).css("border","solid black 100px") ,如此得出的top和 left都会减去100px。 这样感觉怪怪的呢! ---- 再稍微整理一下。在浏览器上测试之後,大概知道了一些东西。 先建一个网页,原始码为 <!DOCTYPE html> <html style="border:2px solid black;margin:1px;padding:4px"> <head> <meta charset="utf-8" /> <script src="jquery-1.8.0.js"></script> <script> $(function() { var a=""; for(var i=0;i<100;i+=1) a+="aa<br>"; $("div").html(a); var div = $("div")[0], doc = div.ownerDocument.documentElement, body = div.ownerDocument.body; window.div = div; window.doc = doc; window.body = body; }) </script> </head> <body style="border:16px solid red;margin:8px;padding:32px"> <div style="border:128px solid blue;margin:64px;padding:256px"> </div> <body> </html> 这里的div是<div>元素,body是<body>元素,doc则是<html>元素。 这样就可以测试了。 div.getBoundingClientRect().top等於127,是视窗原点至div的border外缘 的距离。类似地,body会等於15;doc会等於1。卷轴下移时,数值也会减少, 这也没问题。 div.clientTop等於128,是div的border外缘至padding外缘的距离,其实就是 border的高度(或宽度)。类似地,body会等於16,doc会等於2。卷轴下移时不 变。window.pageYOffset会随着卷轴下移而增加;doc.scrollTop等於0,不随 卷轴下移而变。 最後,$(div).offset().top等於125,不随卷轴下移而变。这个值是什麽意思 呢?doc的margin外缘至div的border外缘,再减去doc的border高度,就是这 个值。而当doc的border高度为0时,这个值的意思又变成了doc的margin外缘 至div的border外缘,再减去body的border高度。 然後再来看一下$(body).offset().top会等於8,这是body的margin高度,可 看成是由doc的padding内缘至body的border外缘的距离。这是由於body是被独 立出来写的,部份程式码如下: var top = body.offsetTop; if ( jQuery.support.doesNotIncludeMarginInBodyOffset ) { top += parseFloat( jQuery.css(body, "marginTop") ) || 0; } 结果,虽然$.fn.offset这个函式似乎是元素和文件原点间的距离,但文件原 点是指什麽?doc的margin外缘左上角?doc的padding内缘左上角?而且还要 减去doc或body之一的border宽度? --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 114.44.138.123
1F:→ tyf99:有把 default body margin 算进去了吗? 09/22 04:21
※ 编辑: kilva 来自: 114.44.138.123 (09/22 07:05) ※ 编辑: kilva 来自: 114.44.138.123 (09/22 11:40) ※ 编辑: kilva 来自: 114.44.138.123 (09/22 16:48)







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:Boy-Girl站内搜寻

TOP