一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

javascript YUI 讀碼日記之 YAHOO.util.Dom - Part.4

var getXY = function() {
    // 判斷是否是 IE
    if (document.documentElement.getBoundingClientRect) {
        // 注1
        return function(el) {
            var box = el.getBoundingClientRect();

            var rootNode = el.ownerDocument;
            return [box.left + 
          Y.Dom.getDocumentScrollLeft(rootNode), box.top +
                    Y.Dom.getDocumentScrollTop(rootNode)];
        };
    } else {
        return function(el) {
            var pos = [el.offsetLeft, el.offsetTop];
            var parentNode = el.offsetParent;

            // 判斷是否在 Safari 下,節(jié)點(diǎn)是否為 absolute ,
            // 并且父元素是否為 body
            // 注2.
            var accountForBody = (isSafari &&
                    Y.Dom.getStyle(el, 'position') == 'absolute' &&
                    el.offsetParent == el.ownerDocument.body);

            // 如果父元素不是自身
            if (parentNode != el) {
                while (parentNode) {
                    pos[0] += parentNode.offsetLeft;
                    pos[1] += parentNode.offsetTop;
                    if (!accountForBody && isSafari && 
                            Y.Dom.getStyle(parentNode,'position') 
                                                  == 'absolute' ) { 
                        accountForBody = true;
                    }
                    parentNode = parentNode.offsetParent;
                }
            }

            // 還是針對 Safari 的
            if (accountForBody) { //safari doubles in this case
                pos[0] -= el.ownerDocument.body.offsetLeft;
                pos[1] -= el.ownerDocument.body.offsetTop;
            } 
            parentNode = el.parentNode;

            // account for any scrolled ancestors
            while ( parentNode.tagName && 
                         !patterns.ROOT_TAG.test(parentNode.tagName) ) 
            {
               // work around opera inline/table scrollLeft/Top bug
               // 注3.
               if (Y.Dom.getStyle(parentNode, 'display')
                                  .search(/^inline|table-row.*$/i)) { 
                    pos[0] -= parentNode.scrollLeft;
                    pos[1] -= parentNode.scrollTop;
                }

                parentNode = parentNode.parentNode; 
            }

            return pos;
        };
    }
}() // NOTE: Executing for loadtime branching注. 有關(guān) IE 的 getBoundingClientRect 方法,可以參考這里。
注. Safari 的 BUG,詳細(xì)情況參見這里。
注. 參見老外的原話(出處):
"- Remove parent scroll UNLESS that parent is inline or a table 
to work around Opera inline/table scrollLeft/Top bug"
Fixed in Opera 9.5. (also, Opera 9.5 supports getBoundingClientRect 
and getClientRects.)最后,有關(guān)更多 DOM 的兼容性,可以參看 PPK 的總結(jié)(怎么又是他)。

JavaScript技術(shù)javascript YUI 讀碼日記之 YAHOO.util.Dom - Part.4,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 中文字幕亚洲激情 | 中文字幕成人网 | 婷婷狠狠干 | 亚洲一区二区三区四区在线观看 | 三级韩国一区久久二区综合 | 日韩久久一区二区三区 | 亚洲综合偷自成人网第页色 | 在线资源观看 | 久久99久久99| 日韩午夜小视频 | 亚洲狠狠狠一区二区三区 | 国产永久免费高清在线观看视频 | 色悠影院 | 久久天天干 | 国产女乱淫真高清免费视频 | 玖玖国产精品视频 | 99精品视频在线播放2 | 中文字幕日韩一区二区三区不 | 国产精品拍自在线观看 | 久久一本色系列综合色 | 涩涩涩视频在线观看免费 | xx视频在线永久免费观看 | 小泽玛利亚一区二区三区免费 | 国产综合久久久久久 | 午夜视频在线看 | 色五夜 | 四色网站 | 亚洲国产区 | 日本激情网址 | 免费91麻豆精品国产自产在线观看 | 国产成人高清视频 | 四虎最新紧急入口 | 永久免费观看视频 | 在线观看成人小视频 | 久久香蕉网| 国产成人无精品久久久久国语 | 国产女乱淫真高清免费视频 | 欧美成人午夜视频免看 | 激性欧美在线播激性欧美 | 天天躁天天弄天天爱 | 91伊人国产 |