獲取dom元素那些討厭的位置封裝代碼
介紹
解決各個(gè)瀏覽器下 獲取dom 元素的 位置
兼容性
ie 6 7 8 firefox 3.6 chrome 4.0 目前只測(cè)試了這幾個(gè)瀏覽器
作者
Jelle · lu QQ:271412542 Email:idche@qq.com blogs:http://www.cnblogs.com/idche/
源碼說(shuō)明
jquery 源碼給我很大幫助,也用到一個(gè)叫 布魯斯 · 李 的同學(xué)的源碼,當(dāng)然更多資源來(lái)源于網(wǎng)絡(luò)。
功能說(shuō)明
// jelle(elem) 對(duì)象 elem傳遞對(duì)象ID 或者 dom對(duì)象 如果是窗口 傳遞 window 對(duì)象
//.offset() 返回當(dāng)前對(duì)象相對(duì)瀏覽器的絕對(duì)位置 ,返回值 = {top:a,left:b};
//.inner() 返回當(dāng)前對(duì)象可見(jiàn)區(qū)域 寬度與高度 ,返回值 = {wisth:a,left:b};
//.scroll() 返回當(dāng)前對(duì)象被卷區(qū)top 和 left。 ,返回值 = {top:a,left:b};
//.offparent() 返回當(dāng)前對(duì)象距離父節(jié)點(diǎn)的位置 top left。 ,返回值 = {top:a,left:b};
//.client() 返回當(dāng)前對(duì)象的可用高度和寬度 ,返回值 = {width:a,height:b};
//.screen() 返回當(dāng)前屏幕的可用高度和寬度 ,返回值 = {width:a,height:b};
//.mouse(event) 返回當(dāng)前鼠標(biāo)的x,y坐標(biāo),elem不為空返回相對(duì)elem的坐標(biāo) ,返回值 = {x:a,y:b};
例子
//例子: 返回一個(gè)ID 為 test 的div 的可見(jiàn)區(qū)域?qū)挾?//jelle('test').inner().width //這里可以緊接后面直接下 width
基于jquery的源碼
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無(wú)標(biāo)題文檔</title>
<style type="text/css">
.jelle_box{ margin:10px; border:5px solid #000; padding:10px; overflow:scroll;}
.o{height:100px;}
.t{height:100px;}
.h{height:100px;}
#jieshao li{ white-space:pre;}
#jieshao li li{ padding:0; margin:0;}
</style>
</head>
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<body>
<dl>
<dt>介紹</dt>
<dd>解決各個(gè)瀏覽器下 獲取dom 元素的 位置</dd>
<dd>兼容性</dd>
<dd>ie 6 7 8 firefox 3.6 chrome 4.0 目前只測(cè)試了這幾個(gè)瀏覽器 </dd>
<dt>作者</dt>
<dd>Jelle · lu QQ:271412542 Email:idche@qq.com blogs:http://www.cnblogs.com/idche/</dd>
<dt>源碼說(shuō)明</dt>
<dd>jquery 源碼給我很大幫助,也用到一個(gè)叫 布魯斯 · 李 的同學(xué)的源碼,當(dāng)然更多資源來(lái)源于網(wǎng)絡(luò)。</dd>
<dt>功能說(shuō)明</dt>
<dd>
<ul id="jieshao">
<li>// jelle(elem) 對(duì)象 elem傳遞對(duì)象ID 或者 dom對(duì)象 如果是窗口 傳遞 window 對(duì)象</li>
<li>//.offset() 返回當(dāng)前對(duì)象相對(duì)瀏覽器的絕對(duì)位置 ,返回值 = {top:a,left:b};</li>
<li>//.inner() 返回當(dāng)前對(duì)象可見(jiàn)區(qū)域 寬度與高度 ,返回值 = {wisth:a,left:b};</li>
<li>//.scroll() 返回當(dāng)前對(duì)象被卷區(qū)top 和 left。 ,返回值 = {top:a,left:b};</li>
<li>//.offparent() 返回當(dāng)前對(duì)象距離父節(jié)點(diǎn)的位置 top left。 ,返回值 = {top:a,left:b};</li>
<li>//.client() 返回當(dāng)前對(duì)象的可用高度和寬度 ,返回值 = {width:a,height:b};</li>
<li>//.screen() 返回當(dāng)前屏幕的可用高度和寬度 ,返回值 = {width:a,height:b};</li>
<li>//.mouse(event) 返回當(dāng)前鼠標(biāo)的x,y坐標(biāo),elem不為空返回相對(duì)elem的坐標(biāo) ,返回值 = {x:a,y:b};
</li>
</ul>
</dd>
<dt>例子</dt>
<dd>//例子: 返回一個(gè)ID 為 test 的div 的可見(jiàn)區(qū)域?qū)挾?
//jelle('test').inner().width
//這里可以緊接后面直接下 width</dd>
</dl>
<textarea id="jelle_code" style="width:300px; height:50px;">jelle('t').offset().top</textarea>
<input type="button" value="運(yùn)行代碼" onclick="alert(eval(document.getElementById('jelle_code').value))" />
<div class="jelle_box o" id="o">
div.id=o
<div class="jelle_box t" id="t">
div.id=t
<br/>
<br/>
<div class="jelle_box h" id="h">div.id=h <br>OK 這里是一個(gè)測(cè)試的地方。他包含3個(gè)DIV嵌套<br/><br/><br/><br/></div><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/>
</div>
<br/><br/><br/><br/>
</div>
<script type="text/javascript">
//****介紹
//解決各個(gè)瀏覽器下 獲取dom 元素的 位置
//****兼容性
// ie 6 7 8 firefox 3.6 chrome 4.0 目前只測(cè)試了這幾個(gè)瀏覽器
//*****作者
// Jelle · lu QQ:271412542 Email:idche@qq.com blogs:http://www.cnblogs.com/idche/
//*****源碼說(shuō)明
// jquery 源碼給我很大幫助,當(dāng)然更多資源來(lái)源于網(wǎng)絡(luò)。
//*****功能說(shuō)明
// jelle(elem) 對(duì)象 elem傳遞對(duì)象ID 或者 dom對(duì)象 如果是窗口 傳遞 window 對(duì)象
//.offset() 返回當(dāng)前對(duì)象相對(duì)瀏覽器的絕對(duì)位置 ,返回值 = {top:a,left:b};
//.inner() 返回當(dāng)前對(duì)象可見(jiàn)區(qū)域 寬度與高度 ,返回值 = {wisth:a,left:b};
//.scroll() 返回當(dāng)前對(duì)象被卷區(qū)top 和 left ,返回值 = {top:a,left:b};
//.offparent() 返回當(dāng)前對(duì)象距離父節(jié)點(diǎn)的位置 top left ,返回值 = {top:a,left:b};
//.client() 返回當(dāng)前對(duì)象的可用高度和寬度 ,返回值 = {width:a,height:b};
//.screen() 返回當(dāng)前屏幕的可用高度和寬度 ,返回值 = {width:a,height:b};
//.mouse(event) 返回當(dāng)前鼠標(biāo)的x,y坐標(biāo) ,返回值 = {x:a,y:b};
//*****例子
//例子: 返回一個(gè)ID 為 test 的div 的可見(jiàn)區(qū)域?qū)挾?
//jelle('test').inner().width
//這里可以緊接后面直接下 width
var jelle=function(elem){
// sys 瀏覽器判斷
var sys=(function(){
var sys={},ua=navigator.userAgent.toLowerCase();
//sys.firefox= ua.match(/firefox\/([\d\.]+)/) || false; //后面沒(méi)有用到所以注銷(xiāo)掉
sys.ie= ua.match(/msie\s([\d\.]+)/) || false;
//sys.chrome= ua.match(/chrome\/([\d\.]+)/) || false; //后面沒(méi)有用到所以注銷(xiāo)掉
return sys;
})(),
comStyle=function(obj){
return window.getComputedStyle ? window.getComputedStyle(obj, null) : obj.currentStyle;
},
// elem 當(dāng)前對(duì)象 window or other object
elem= typeof elem === 'string' ? document.getElementById(elem) :
elem === undefined ? window : elem,
isie=/^6.0|7.0|8.0$/.test(sys.ie[1]),//是否IE 瀏覽器
isie67=/^6.0|7.0$/.test(sys.ie[1]),
db=document.body,
dd=document.documentElement,
_this={};
//對(duì)象距離瀏覽器對(duì)0 0點(diǎn)的距離
_this.offset=function(o){
//感謝 糖粒子 告訴我這個(gè)方法
//有了這個(gè)方法至少省略了 15行代碼
return (o?o:elem).getBoundingClientRect();
}
//當(dāng)前對(duì)象可見(jiàn)區(qū)域的寬 高 window
_this.inner=function(){
var width,height;
//not window object
if ( elem !== window ) {
var computedStyle=comStyle(elem);
width=elem.offsetWidth;
height=elem.offsetHeight;
//isie=/^6.0|7.0|8.0$/.test(sys.ie[1]),
if( isie ){
width-=parseInt(computedStyle.marginTop) || 0;
height-=parseInt(computedStyle.marginLeft) || 0;
}else{
width-=parseInt(computedStyle.paddingTop) || 0;
height-=parseInt(computedStyle.paddingLeft) || 0;
}
} else{
// window 需要區(qū)分瀏覽器
//isie=/^6.0|7.0|8.0$/.test(sys.ie[1]),
if ( isie ){
width=dd.offsetWidth;
height=dd.offsetHeight;
}else{
//當(dāng)前elem=window
width=elem.innerWidth;
height=elem.innerHeight;
}
}
// 返回的數(shù)據(jù)格式{width:a,height:b}
return {'width':width,'height':height};
}
//獲取對(duì)象滾動(dòng)條卷去的距離
_this.scroll=function(o){
var _elem = o ? o : elem,top,left;
if( _elem === window){
top=db.scrollTop+dd.scrollTop;
left=db.scrollLeft+dd.scrollLeft;
}else{
top=_elem.scrollTop || 0;
left=_elem.scrollLeft || 0;
}
return { 'top':top , 'left':left };
}
//獲取對(duì)象距離父節(jié)點(diǎn)的 位置
_this.offparent=function(){
return {'top':_this.offset(elem).top - _this.offset(elem.parentNode).top,
'left':_this.offset(elem).left - _this.offset(elem.parentNode).left
};
}
//當(dāng)前對(duì)象的可用高度與寬度
_this.client=function(){
return elem==window ? {'width':db.clientWidth,'height':db.clientHeight} :
{'height':elem.scrollWidth,'height':elem.scrollHeight};
}
//屏幕可用工作區(qū)寬度高度
_this.screen=function(){
return {'width':window.screen.availWidth,'height':window.screen.availHeight,}
}
//獲取當(dāng)前鼠標(biāo)的位置
_this.mouse=function (e){//獲取鼠標(biāo)坐標(biāo) 請(qǐng)傳遞evnet參數(shù)
var e = window.event || e,
p=(e.pageX || e.pageY)?{ x:e.pageX, y:e.pageY } :
{ x:e.clientX + db.scrollLeft - db.clientLeft, y:e.clientY + db.scrollTop - db.clientTop };
return elem === window ? p :
{x:p.y - _this.offset().top, y:p.x - _this.offset().left};
}
return _this;
}
</script>
</body>
</html>
相關(guān)文章
Javascript 阻止瀏覽器默認(rèn)操作的實(shí)現(xiàn)代碼
在瀏覽器事件中,會(huì)觸發(fā)一些默認(rèn)動(dòng)作,比如:點(diǎn)擊一個(gè)鏈接時(shí),執(zhí)行完捕獲/冒泡動(dòng)作后,會(huì)觸發(fā)鏈接的默認(rèn)事件:跳轉(zhuǎn)到指定鏈接地址。2009-09-09bootstrap fileinput插件實(shí)現(xiàn)預(yù)覽上傳照片功能
這篇文章主要介紹了bootstrap fileinput插件實(shí)現(xiàn)預(yù)覽上傳照片功能,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-01-01JS(JQuery)操作Array的相關(guān)方法介紹
本篇文章主要是對(duì)JS(JQuery)操作Array的相關(guān)方法進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02uni-app調(diào)取接口的3種方式以及封裝uni.request()詳解
我們?cè)趯?shí)際工作中要將數(shù)據(jù)傳輸?shù)椒?wù)器端,從服務(wù)器端獲取信息,都是通過(guò)接口的形式,下面這篇文章主要給大家介紹了關(guān)于uni-app調(diào)取接口的3種方式以及封裝uni.request()的相關(guān)資料,需要的朋友可以參考下2022-08-08Jupyter Notebook運(yùn)行JavaScript的方法
Jupyter Notebook是一塊所見(jiàn)即所得的畫(huà)布,通過(guò)在瀏覽器上編輯代碼,讓開(kāi)發(fā)人員實(shí)現(xiàn)展示與快速迭代的利器,本文主要介紹了Jupyter Notebook運(yùn)行JavaScript的方法,感興趣的可以了解一下2021-05-05JavaScript提取元素中第一個(gè)子元素的實(shí)現(xiàn)方法
本文主要介紹了JavaScript提取元素中第一個(gè)子元素的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06JS實(shí)現(xiàn)鼠標(biāo)移上去顯示圖片或微信二維碼
本文給大家分享一段使用的js代碼實(shí)現(xiàn)鼠標(biāo)移入顯示圖片或微信二維碼樣式,代碼簡(jiǎn)單易懂,非常不錯(cuò),需要的朋友參考下吧2016-12-12如何讓一個(gè)json文件顯示在表格里【實(shí)現(xiàn)代碼】
如何讓一個(gè)json文件顯示在表格里?下面小編就為大家?guī)?lái)一篇讓一個(gè)json文件顯示在表格里的實(shí)現(xiàn)代碼。希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧,祝大家游戲愉快哦2016-05-05js 數(shù)組實(shí)現(xiàn)一個(gè)類(lèi)似ruby的迭代器
今天突然發(fā)現(xiàn)js的數(shù)組處理起來(lái)真是麻煩,代碼一些就是一大堆,相比起ruby的迭代器來(lái)真是遜色不少。2009-10-10