手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >javascript获取隐藏dom的宽高 具体实现
javascript获取隐藏dom的宽高 具体实现
摘要:首先clone一个DOM,设置position:absolute,然后设置top为一个比较大的负值,然后使其显示出来,最后获取到了DOM的宽...

首先clone一个DOM,设置position:absolute,然后设置top为一个比较大的负值,然后使其显示出来,最后获取到了DOM的宽高后,将其remove。

具体代码如下:

Js代码

复制代码 代码如下:

function getCss(elem, css){

if (window.getComputedStyle) {

return window.getComputedStyle(elem, null)[css];

}else if (elem.currentStyle) {

return elem.currentStyle[css];

}else {

return elem.style[css];

}

}

function getWH(dom){

var get = function(elem){

var wh = {};

'Width Height'.replace(/[^ ]+/g, function(i){

var a = i.toLowerCase();

wh[a] = elem['offset' + i] || elem['client' + i];

});

return wh;

};

if (getCss(dom, 'display') === 'none') {

var nDom = dom.cloneNode(true);

nDom.style.position = 'absolute';

nDom.style.top = '-3000px';

nDom.style.display = 'block';

document.getElementsByTagName('body')[0].appendChild(nDom);

var wh = get(nDom);

nDom.parentNode.removeChild(nDom);

return wh;

}

return get(dom);

}

//test

console.log(getWH(document.getElementById('content')));

var domA = document.createElement("a"), _ostyle = "position:absolute;z-index:999999;width:92px;height:22px;position:absolute;display:none;";

domA.setAttribute("style", _ostyle);

domA.style.cssText = _ostyle;

domA.setAttribute("href", "javascript:void(0);");

document.getElementsByTagName('body')[0].appendChild(o);

console.log(getWH(domA));

function getCss(elem, css){

if (window.getComputedStyle) {

return window.getComputedStyle(elem, null)[css];

}else if (elem.currentStyle) {

return elem.currentStyle[css];

}else {

return elem.style[css];

}

}

function getWH(dom){

var get = function(elem){

var wh = {};

'Width Height'.replace(/[^ ]+/g, function(i){

var a = i.toLowerCase();

wh[a] = elem['offset' + i] || elem['client' + i];

});

return wh;

};

if (getCss(dom, 'display') === 'none') {

var nDom = dom.cloneNode(true);

nDom.style.position = 'absolute';

nDom.style.top = '-3000px';

nDom.style.display = 'block';

document.getElementsByTagName('body')[0].appendChild(nDom);

var wh = get(nDom);

nDom.parentNode.removeChild(nDom);

return wh;

}

return get(dom);

}

//test

console.log(getWH(document.getElementById('content')));

var domA = document.createElement("a"), _ostyle = "position:absolute;z-index:999999;width:92px;height:22px;position:absolute;display:none;";

domA.setAttribute("style", _ostyle);

domA.style.cssText = _ostyle;

domA.setAttribute("href", "javascript:void(0);");

document.getElementsByTagName('body')[0].appendChild(o);

console.log(getWH(domA));

还有其他更好的方法欢迎提出来。

【javascript获取隐藏dom的宽高 具体实现】相关文章:

JavaScript深度复制(deep clone)的实现方法

Javascript 字符串模板的简单实现

javascript常用的方法分享

javascript搜索框效果实现方法

javascript元素动态创建实现方法

javascript瀑布流布局实现方法详解

详解JavaScript中void语句的使用

javascript结合Flexbox简单实现滑动拼图游戏

javasript实现密码的隐藏与显示

javascript制作的滑动图片菜单

精品推荐
分类导航