zoukankan      html  css  js  c++  java
  • 获取控件元素的绝对位置|

    function getElementPos(elementId) {
    var ua = navigator.userAgent.toLowerCase();
    var isOpera = (ua.indexOf('opera') != -1);
    var isIE = (ua.indexOf('msie') != -1 && !isOpera); // not opera spoof
    var el = document.getElementById(elementId);
    if(el.parentNode === null || el.style.display == 'none') {
       return false;
    }     
    var parent = null;
    var pos = [];    
    var box;    
    if(el.getBoundingClientRect) {
    //IE
       box = el.getBoundingClientRect();
       var scrollTop = Math.max(document.documentElement.scrollTop, document.body.scrollTop);
       var scrollLeft = Math.max(document.documentElement.scrollLeft, document.body.scrollLeft);
       return {x:box.left + scrollLeft, y:box.top + scrollTop};
      
    } else if (document.getBoxObjectFor) {
    // gecko
       box = document.getBoxObjectFor(el);
       var borderLeft = (el.style.borderLeftWidth)?parseInt(el.style.borderLeftWidth):0;
       var borderTop = (el.style.borderTopWidth)?parseInt(el.style.borderTopWidth):0;
       pos = [box.x - borderLeft, box.y - borderTop];
      
    } else { // safari & opera
       pos = [el.offsetLeft, el.offsetTop];
       parent = el.offsetParent;    
       if (parent != el) {
        while (parent) {
         pos[0] += parent.offsetLeft;
         pos[1] += parent.offsetTop;
         parent = parent.offsetParent;
        }
       }  
       if (ua.indexOf('opera') != -1 || ( ua.indexOf('safari') != -1 && el.style.position == 'absolute' )) {
        pos[0] -= document.body.offsetLeft;
        pos[1] -= document.body.offsetTop;        
       }   
    }             
    if (el.parentNode) {
       parent = el.parentNode;
    } else {
       parent = null;
    }
    while (parent && parent.tagName != 'BODY' && parent.tagName != 'HTML') { // account for any scrolled ancestors
       pos[0] -= parent.scrollLeft;
       pos[1] -= parent.scrollTop;
       if (parent.parentNode) {
        parent = parent.parentNode;
       } else {
        parent = null;
       }
    }
    return {x:pos[0], y:pos[1]};
    }
  • 相关阅读:
    验证码缓存问题完美解决方案
    最近项目是跟框架有关的两个问题
    未与信任 SQL Server 连接相关联
    Get请求
    Post请求
    jQuery操作元素
    Dom对象和jQuery包装集
    XMLHttpRequest对象
    jQuery事件与事件对象
    处理数据集
  • 原文地址:https://www.cnblogs.com/bestsaler/p/1835871.html
Copyright © 2011-2022 走看看