欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript獲取文檔坐標(biāo)和視口坐標(biāo)

 更新時(shí)間:2015年05月26日 10:21:19   投稿:hebedich  
制作網(wǎng)頁的過程中,你有時(shí)候需要知道某個(gè)元素在網(wǎng)頁上的確切位置。下面的教程總結(jié)了Javascript在網(wǎng)頁定位方面的相關(guān)知識(shí)。有需要的小伙伴可以參考下。

元素的位置是以像素度量的,向右代表X坐標(biāo)的增加,向下代表Y坐標(biāo)的增加,但是,有兩個(gè)不同的點(diǎn)作為坐標(biāo)系的原點(diǎn):元素的X和Y坐標(biāo)可以相對(duì)于文檔的左上角或者相對(duì)于在職中顯示文檔的視口的左上角。

在定級(jí)窗口和標(biāo)簽頁中,”視口“只是實(shí)際顯示文檔內(nèi)容的瀏覽器的一部分:它不包括瀏覽器的“外殼”(如菜單、工具條和標(biāo)簽頁)。

針對(duì)框架也中顯示的文檔,是口試定了框架頁的<iframe>元素。無論在何種情況下,當(dāng)討論元素的位置是,必須弄清楚所使用的坐標(biāo)是文檔坐標(biāo)還是視口坐標(biāo)。(注意,視口坐標(biāo)有事也叫作窗口坐標(biāo))

如果文檔比視口要小,或者說還未出現(xiàn)滾動(dòng),則文檔的左上角就是視口的左上角,文檔和視口坐標(biāo)系統(tǒng)是同一個(gè)。但是一般來說,要在兩種坐標(biāo)系之間互相轉(zhuǎn)換,必須加上或減去滾動(dòng)的偏移量(scroll offset)。例如,在文檔坐標(biāo)中如果一個(gè)元素的Y坐標(biāo)是200像素,并且用戶已經(jīng)把瀏覽器向下滾動(dòng)了75像素,那么視口坐標(biāo)中元素的Y坐標(biāo)就是125像素。同樣,在視口坐標(biāo)中如果一個(gè)元素的X坐標(biāo)是400像素,并且用戶已經(jīng)水平滾動(dòng)了視口200像素,那么文檔坐標(biāo)中像素的X坐標(biāo)中元素的X坐標(biāo)就是600像素。

文檔坐標(biāo)比視口坐標(biāo)更加基礎(chǔ),并且在用戶滾動(dòng)是他們不會(huì)發(fā)生變化。不過,在客戶端編程中使用視口坐標(biāo)是非常常見的。當(dāng)使用CSS指定元素的位置時(shí)運(yùn)用了文檔坐標(biāo)。但是最簡單的查詢?cè)匚恢玫姆椒ǎ篻etBoundingClientRect()返回視口坐標(biāo)中的位置。類似的,當(dāng)為鼠標(biāo)事件注冊(cè)事件處理程序函數(shù)時(shí),報(bào)告的鼠標(biāo)指針的坐標(biāo)是在視口坐標(biāo)系中。

為了在坐標(biāo)系中轉(zhuǎn)換,我們需要判定瀏覽器窗口的滾動(dòng)條的位置。Window對(duì)象的pageXoffset和pageYOffset屬性在所有的瀏覽器中提供這些值,除了IE8及更早的版本以外。IE(和所有現(xiàn)代瀏覽器)也可以通過scrollLeft和scrollTop屬性來獲得滾動(dòng)條的位置。令人迷惑的是,正常的情況下通過查找文檔的根節(jié)點(diǎn)(document.documentElement)來獲取這些屬性,但是在怪異模式下,必須在文檔的<body>元素(documeng.body)上查詢它們。以下顯示了如何簡便的查詢滾動(dòng)條的位置。

functon getScrollOffsets(w){
  w = w || window;
  var sLeft,sTop;
  if(w.pageXOffset != null) {
    sLeft = w.pageXOffset;
    sTop = w.pageYOffset;
    return {x:sLeft,y:sTop};
  }
  if(document.compatMode == "CSS1Compat"){
    sLeft = document.documentElement.scrollLeft == 0 ? document.body.scrollLeft : document.documentElement.scrollLeft; 
    sTop = document.documentElement.scrollTop == 0 ? document.body.scrollTop : document.documentElement.scrollTop;  
    return {x:sLeft,y:sTop};
  }else if(document.compatMode == "BackCompat"){
    sLeft = document.body.scrollLeft; 
    sTop = document.body.scrollTop;
    return {x:sLeft,y:sTop};  
  }
}

有時(shí)候能夠判定視口的尺寸也是非常有用的,例如,為了確定文檔的案部分是當(dāng)前可見的。利用滾動(dòng)偏移量查詢視口的尺寸的簡單方法在IE8及更早版本中無法工作,而且該技術(shù)在IE中的運(yùn)行法師還要取決于瀏覽器是否處于怪異模式還是標(biāo)準(zhǔn)模式。

window下的屬性:

innerHeight:包括滾動(dòng)條在內(nèi)的窗口內(nèi)容部分的高度

innerWidth:包括滾動(dòng)條在內(nèi)的窗口內(nèi)容部分的寬度

outerHeight:整個(gè)瀏覽器的高度,包括界面所有組成部分。

outerWidth:整個(gè)瀏覽器的寬度,包括界面所有組成部分。

pageXOffset:瀏覽器窗口的滾動(dòng)條X軸的位置

pageYOffset:瀏覽器窗口的滾動(dòng)條Y軸的位置

scrollX:瀏覽器窗口的滾動(dòng)條X軸的位置

scrollY:瀏覽器窗口的滾動(dòng)條Y軸的位置

屬性

document.documentElement document.body
clientHeight 視口內(nèi)可見內(nèi)容的大小,不包括滾動(dòng)的部分和滾動(dòng)條。
clientWidth
clientLeft     
clientTop   
offsetHeight 內(nèi)容大小,并且包括滾動(dòng)條。
offsetWidth
offsetLeft   
offsetTop   
scrollHeight 滾動(dòng)內(nèi)容的大小,包括滾動(dòng)的部分,但不包括滾動(dòng)條。
scrollWidth
scrollTop   
scrollWidth   

查詢窗口的視口尺寸:

function getViewportSize(w){
  w = w || window;
  var cWidth,cHeight;
  if(w.innerWidth != null){
    cWidth = w.innerWidht;
    cHeight = w.innerHeight;
    return {w:cWidth,h:w.cHeight};
  }
  if(document.compatMode == "CSS1Compat"){
    cWidth = document.documentElement.clientWidth;
    cHeight = doument.documentElement.clientHeight;
    return {w:cWidth,h:w.cHeight};
  }else if(document.compatMode == "BackCompat"){
    cWidth = document.body.clientWidth;
    cHeight = doument.body.clientHeight;
    return {w:cWidth,h:w.cHeight};
  }
}

以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。

相關(guān)文章

最新評(píng)論