成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

BOM-各種寬高

MageekChiu / 3176人閱讀

摘要:表示元素可見課件內(nèi)容的高度,包括以下幾部分可見內(nèi)容包括的高度,隱藏內(nèi)容由于存在垂直滾動(dòng)條不被包括。

1. window下的寬高

獲取高度可以可以省略window

window.innerWidth,通過字面意思我們知道這是一個(gè)內(nèi)部的寬度,如果有滾動(dòng)條,則包含滾動(dòng)條的寬度

window.innerHeight,表示內(nèi)部可用的高度,如果有滾動(dòng)條,則包含滾動(dòng)條的高度

window.outWidth,整個(gè)窗口的寬度

window.outHeight,整個(gè)窗口的高度

此外還有window.screen下的寬度,主要是與屏幕間的距離

幾大差異

屬性名 描述 備注
window.innerHeight 瀏覽器的窗口高度,如果有水平滾動(dòng)條則包含滾動(dòng)條的高度 只讀屬性,IE8及以下不支持
document.documentElement.clientHeight 不包括滾動(dòng)條,包含html元素邊框
document.body.clientHeight 不包含滾動(dòng)條,不包含htmlbody的邊框和滾動(dòng)條
2. document下的寬高

首先來看一張各種尺寸的圖地址

document下一共有三種相關(guān)的寬高

client相關(guān)的寬高

offset相關(guān)的寬高

scroll相關(guān)的寬高

offsetHeigth表示 VISIBLE content & padding + border + scrollbar,也就是內(nèi)容的可見區(qū)域加上padding和border和滾動(dòng)條(如果有)

clientHeight表示VISIBLE content & padding,也就是可見區(qū)域的高度加上padding

scrollHeight表示ENTIRE content & padding(visible or hidden),也就是整個(gè)內(nèi)容的高度加上padding(可見或者隱藏)

當(dāng)我們給div設(shè)置寬度和高度時(shí),我們其實(shí)設(shè)置的是content area的寬高,同理padding和border也是一樣,所以元素的總高度為content+margin+padding

1. offsetHeight

offsetHeight表示元素在HTML頁(yè)面當(dāng)中所占據(jù)的高度,當(dāng)使用開發(fā)者工具,移到div上,所顯示的寬高即是實(shí)際占用的高度,包括以下幾部分:

可見內(nèi)容區(qū)的高度,隱藏的內(nèi)容由于存在滾動(dòng)條,不被包含

水平滾動(dòng)條的高度

頂部和底部的border

margin由于是隔離元素的一部分,因此不被包含。

2. clientHeight

clientHeight表示元素可見課件內(nèi)容的高度,包括以下幾部分:

可見內(nèi)容(包括padding)的高度,隱藏內(nèi)容由于存在垂直滾動(dòng)條不被包括。

3. scrollHeight

scrollHeight表示可見/隱藏元素的總高度,包括以下幾部分:

可見內(nèi)容的高度包括padding

隱藏內(nèi)容的高度包括padding

不包括border和margin

在線demo

3. HTMLElement.scrollXXX屬性

下面的屬性均為只讀屬性,返回當(dāng)前元素相對(duì)scrollParent的距離

c.offsetLeft 和 c.offsetTop

一般指當(dāng)前元素的CSS邊框相對(duì)于其offsetParent的X和Y坐標(biāo)

c.offsetHeight 和 c.offsetWidth

當(dāng)前元素及其所有內(nèi)容的高度,寬度。

c.offsetParent

離當(dāng)前元素最近的定位元素,定位屬性包括relative,absolute等,標(biāo)準(zhǔn)模式下為html,怪異模式下為body

4. 兼容方案 1. 瀏覽器可視區(qū)寬高
let height = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight;
let width = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth
2.當(dāng)前元素距離文檔頂部距離

當(dāng)offsetParentbody的時(shí)候,可以通過el.offsetTop確定距離文檔頂部的高度,可以使用下面的方法來判斷

function getTop(el) {
  let top = el.offsetTop;
  let currentParent = el.offsetParent;
  while (currentParent != null) {
    top += currentParent.offsetTop;
    currentParent = currentParent.offsetParent;
  }
  return top;
}
3.滾動(dòng)(被卷去)的高度

兼容方案

window.pageYOffsetwindow.scrollY的別名

scrollTop表示距離scrollParent被卷去的距離,

scrollheight是元素的整個(gè)高度,包括overflow隱藏的部分

var x = window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft
var y = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop

是否滾動(dòng)到底部

// 文檔高度 - 滾動(dòng)的高度 === 視口高度
ele.scrollHeight - ele.scrollTop === ele.clientHeight;

// 文檔高度,包括padding,不包括border
ele.scrollHeight = document.documentElement.scrollheight;

// 滾動(dòng)的高度
ele.scrollTop = Math.round(document.documentElement.scrollTop);

// 視口高度
ele.clientHeight = document.documentElement.clientHeight;
場(chǎng)景一: 懶加載的實(shí)現(xiàn)

需要獲取的高度

var clientY = window.innerheight || document.documentElement.clientheight || document.body.clientHeight;


// 兼容方案
var supportPageOffset = window.pageXOffset !== undefined;
var isCSS1Compat = ((document.compatMode || "") === "CSS1Compat");

var x = supportPageOffset ? window.pageXOffset : isCSS1Compat ? document.documentElement.scrollLeft : document.body.scrollLeft;
var y = supportPageOffset ? window.pageYOffset : isCSS1Compat ? document.documentElement.scrollTop : document.body.scrollTop;

判斷圖片是否出現(xiàn)在視窗里面,主要有三個(gè)高度

當(dāng)前的body從頂部滾動(dòng)了多少距離 document.body.scrollTop

視窗的距離 window.innerHeight

當(dāng)前圖片距離頂部的距離 offsetTop

兩個(gè)常見的滾動(dòng)判定

頁(yè)面滾動(dòng)離開首屏(這時(shí)可顯示回到頂部的按鈕): document.body.scrollTop > window.innerHeight

頁(yè)面滾動(dòng)到底部了(這時(shí)可去調(diào)接口獲取更多內(nèi)容): window.scrollY + window.innerHeight > document.body.scrollHeight

    function isBottomVisible () {
      var scrollY = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop;
      var clientY = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight;
      var pageY = document.documentElement.scrollHeight || document.body.scrollHeight; 
      // console.log(scrollY,clientY,pageY);
      
      return Math.round(scrollY) + clientY === pageY
    },
場(chǎng)景二:滾動(dòng)到指定位置
// 滾動(dòng)到指定位置
window.scrollTo(0,100);
window.scroll(0,100);

// 計(jì)算垂直滾動(dòng)條的距離
if (document.body.clientWidth !== window.innerWidth) {
    var scrollHeight = window.innerWidth - document.body.clientWidth;
}

// 滾到頂部
if (window.scrollY) {
    window.scroll(0,0);
}
Reference

SRC

MDN

blog

size and scroll window

size and scroll

JavaScript學(xué)習(xí)筆記:視口寬高、位置與滾動(dòng)高度

SF

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/96648.html

相關(guān)文章

  • BOM-各種寬高

    摘要:表示元素可見課件內(nèi)容的高度,包括以下幾部分可見內(nèi)容包括的高度,隱藏內(nèi)容由于存在垂直滾動(dòng)條不被包括。 1. window下的寬高 獲取高度可以可以省略window window.innerWidth,通過字面意思我們知道這是一個(gè)內(nèi)部的寬度,如果有滾動(dòng)條,則包含滾動(dòng)條的寬度 window.innerHeight,表示內(nèi)部可用的高度,如果有滾動(dòng)條,則包含滾動(dòng)條的高度 window.o...

    Yuanf 評(píng)論0 收藏0
  • BOM-各種寬高

    摘要:表示元素可見課件內(nèi)容的高度,包括以下幾部分可見內(nèi)容包括的高度,隱藏內(nèi)容由于存在垂直滾動(dòng)條不被包括。 1. window下的寬高 獲取高度可以可以省略window window.innerWidth,通過字面意思我們知道這是一個(gè)內(nèi)部的寬度,如果有滾動(dòng)條,則包含滾動(dòng)條的寬度 window.innerHeight,表示內(nèi)部可用的高度,如果有滾動(dòng)條,則包含滾動(dòng)條的高度 window.o...

    fantix 評(píng)論0 收藏0
  • 前端開發(fā)

    摘要:前端開發(fā)前端概述一什么是前端前端即網(wǎng)絡(luò)站前臺(tái)部分,運(yùn)行在端,移動(dòng)端等瀏覽器上展現(xiàn)給用戶瀏覽的頁(yè)面。文件后綴前端三劍客一標(biāo)記語(yǔ)言標(biāo)記語(yǔ)言為非標(biāo)記語(yǔ)言,不具備編程語(yǔ)言具備的程序邏輯為前端頁(yè)面的主體,有標(biāo)簽指令與轉(zhuǎn)義字符等組成。前端開發(fā) 前端概述 一、什么是前端 前端即網(wǎng)絡(luò)站前臺(tái)部分,運(yùn)行在pc端,移動(dòng)端等瀏覽器上展現(xiàn)給用戶瀏覽的頁(yè)面。隨著互聯(lián)網(wǎng)技術(shù)的發(fā)展,HTML5,CSS3,前端框架的應(yīng)用,...

    SQC 評(píng)論0 收藏0
  • JavaScript 基礎(chǔ)知識(shí) - BOM

    摘要:在中我們需要掌握定時(shí)器。定時(shí)器不是我們調(diào)用,我們只需要把函數(shù)的地址傳過去,時(shí)間到了,會(huì)自己調(diào)用。參數(shù)延時(shí)的時(shí)間單位毫秒返回定時(shí)器的,用于清除示例代碼延時(shí)定時(shí)器秒后將執(zhí)行的代碼。 showImg(https://segmentfault.com/img/remote/1460000012575821?w=1920&h=1080); 前言 本篇文章是JavaScript基礎(chǔ)知識(shí)的BOM篇,...

    garfileo 評(píng)論0 收藏0
  • JavaScript 基礎(chǔ)知識(shí) - BOM

    摘要:在中我們需要掌握定時(shí)器。定時(shí)器不是我們調(diào)用,我們只需要把函數(shù)的地址傳過去,時(shí)間到了,會(huì)自己調(diào)用。參數(shù)延時(shí)的時(shí)間單位毫秒返回定時(shí)器的,用于清除示例代碼延時(shí)定時(shí)器秒后將執(zhí)行的代碼。 showImg(https://segmentfault.com/img/remote/1460000012575821?w=1920&h=1080); 前言 本篇文章是JavaScript基礎(chǔ)知識(shí)的BOM篇,...

    Object 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<