JS鼠標(biāo)事件中clientX/screenX/offsetX/pageX等等屬性的總結(jié)
今天在處理鼠標(biāo)事件的時候,事件的一堆屬性看的很模糊,專門查看了一下MDN上的解釋:https://developer.mozilla.org/zh-CN/docs/Web/API/MouseEvent 多看看上面的解釋。
鼠標(biāo)事件屬性
主要分為MouseEvent.clientX、MouseEvent.clientY、MouseEvent.movementX、MouseEvent.movementY、MouseEvent.offsetX、MouseEvent.offsetY、MouseEvent.pageX、MouseEvent.pageY、MouseEvent.screenX、MouseEvent.screenY、MouseEvent.x、MouseEvent.y
MouseEvent.clientX是只讀屬性, 它提供事件發(fā)生時的應(yīng)用客戶端區(qū)域的水平坐標(biāo) (與頁面坐標(biāo)不同)。例如,不論頁面是否有水平滾動,當(dāng)你點擊客戶端區(qū)域的左上角時,鼠標(biāo)事件的 clientX 值都將為 0 。最初這個屬性被定義為長整型(long integer),如今 CSSOM 視圖模塊將其重新定義為雙精度浮點數(shù)(double float)。你可以查閱瀏覽器兼容性部分的文檔來進一步了解有關(guān)信息。MouseEvent.clientY是只讀屬性, 它提供事件發(fā)生時的應(yīng)用客戶端區(qū)域的垂直坐標(biāo) (與頁面坐標(biāo)不同)。例如,當(dāng)你點擊客戶端區(qū)域的左上角時,鼠標(biāo)事件的 clientY 值為 0 ,這一值與頁面是否有垂直滾動無關(guān)。MouseEvent.movementX是只讀屬性,它提供了當(dāng)前事件和上一個mousemove事件之間鼠標(biāo)在水平方向上的移動值。換句話說,這個值是這樣計算的 : currentEvent.movementX = currentEvent.screenX - previousEvent.screenX.MouseEvent.movementY是只讀屬性,它提供了當(dāng)前事件和上一個 mousemove 事件之間鼠標(biāo)在水平方向上的移動值。換句話說,這個值是這樣計算的 :currentEvent.movementY = currentEvent.screenY - previousEvent.screenY.MouseEvent.offsetX規(guī)定了事件對象與目標(biāo)節(jié)點的內(nèi)填充邊(padding edge)在 X 軸方向上的偏移量。MouseEvent.offsetY規(guī)定了事件對象與目標(biāo)節(jié)點的內(nèi)填充邊(padding edge)在 Y 軸方向上的偏移量。MouseEvent.pageX是一個由MouseEvent接口返回的相對于整個文檔的x(水平)坐標(biāo)以像素為單位的只讀屬性。這個屬性將基于文檔的邊緣,考慮任何頁面的水平方向上的滾動。舉個例子,如果頁面向右滾動 200px 并出現(xiàn)了滾動條,這部分在窗口之外,然后鼠標(biāo)點擊距離窗口左邊 100px 的位置,pageX 所返回的值將是 300。MouseEvent.pageY是一個只讀屬性,它返回觸發(fā)事件的位置相對于整個 document 的 Y 坐標(biāo)值。由于其參考物是整個 dom,所以這個值受頁面垂直方向的滾動影響。例如:當(dāng)你垂直方向向下滾動了 50 pixel,那么你在頂端進行點擊的時候,獲取的pageY為 50pixed 而不是 0。MouseEvent.screenX是只讀屬性,他提供了鼠標(biāo)相對于屏幕坐標(biāo)系的水平偏移量。MouseEvent.screenY是只讀屬性,它提供了鼠標(biāo)相對于屏幕坐標(biāo)系的垂直偏移量。MouseEvent.x是 MouseEvent.clientX 屬性的別名.MouseEvent.y屬性是 MouseEvent.clientY 屬性的別稱。

元素屬性
官方文檔解釋 https://developer.mozilla.org/zh-CN/docs/Web/API/HTMLElement
Element 是一個通用性非常強的基類,所有 Document 對象下的對象都繼承自它。這個接口描述了所有相同種類的元素所普遍具有的方法和屬性。一些接口繼承自 Element 并且增加了一些額外功能的接口描述了具體的行為。例如, HTMLElement 接口是所有 HTML 元素的基本接口,而 SVGElement 接口是所有 SVG 元素的基礎(chǔ)。大多數(shù)功能是在這個類的更深層級(hierarchy)的接口中被進一步制定的。
Element.clientHeight是只讀屬性,對于沒有定義CSS或者內(nèi)聯(lián)布局盒子的元素為0,否則,它是元素內(nèi)部的高度(單位像素),包含內(nèi)邊距,但不包括水平滾動條、邊框和外邊距。clientHeight 可以通過 CSS height + CSS padding - 水平滾動條高度 (如果存在)來計算.Element.clientWidth只讀屬性,內(nèi)聯(lián)元素以及沒有 CSS 樣式的元素的 clientWidth 屬性值為 0。Element.clientWidth 屬性表示元素的內(nèi)部寬度,以像素計。該屬性包括內(nèi)邊距,但不包括垂直滾動條(如果有)、邊框和外邊-

Element.clientLeft表示一個元素的左邊框的寬度,以像素表示。如果元素的文本方向是從右向左(RTL, right-to-left),并且由于內(nèi)容溢出導(dǎo)致左邊出現(xiàn)了一個垂直滾動條,則該屬性包括滾動條的寬度。clientLeft 不包括左外邊距和左內(nèi)邊距。clientLeft 是只讀的。Element.clientTop一個元素頂部邊框的寬度(以像素表示)。不包括頂部外邊距或內(nèi)邊距。clientTop 是只讀的。-

-
Element.scrollHeight這個只讀屬性是一個元素內(nèi)容高度的度量,包括由于溢出導(dǎo)致的視圖中不可見內(nèi)容。scrollHeight 的值等于該元素在不使用滾動條的情況下為了適應(yīng)視口中所用內(nèi)容所需的最小高度。 沒有垂直滾動條的情況下,scrollHeight值與元素視圖填充所有內(nèi)容所需要的最小值clientHeight相同。包括元素的padding,但不包括元素的border和margin。scrollHeight也包括 ::before 和 ::after這樣的偽元素。 -
Element.scrollWidth這個只讀屬性是元素內(nèi)容寬度的一種度量,包括由于overflow溢出而在屏幕上不可見的內(nèi)容。scrollWidth值等于元素在不使用水平滾動條的情況下適合視口中的所有內(nèi)容所需的最小寬度。 寬度的測量方式與clientWidth相同:它包含元素的內(nèi)邊距,但不包括邊框,外邊距或垂直滾動條(如果存在)。 它還可以包括偽元素的寬度,例如::before或::after。 如果元素的內(nèi)容可以適合而不需要水平滾動條,則其scrollWidth等于clientWidth -

-
Element.scrollLeft可以讀取或設(shè)置元素滾動條到元素左邊的距離。注意如果這個元素的內(nèi)容排列方向(direction) 是rtl (right-to-left) ,那么滾動條會位于最右側(cè)(內(nèi)容開始處),并且scrollLeft值為0。此時,當(dāng)你從右到左拖動滾動條時,scrollLeft會從0變?yōu)樨?fù)數(shù)(這個特性在chrome瀏覽器中不存在)。 -
Element.scrollTop可以獲取或設(shè)置一個元素的內(nèi)容垂直滾動的像素數(shù)。一個元素的 scrollTop 值是這個元素的頂部到視口可見內(nèi)容(的頂部)的距離的度量。當(dāng)一個元素的內(nèi)容沒有產(chǎn)生垂直方向的滾動條,那么它的 scrollTop 值為0。 -

-
HTMLElement接口屬性
-
HTMLElement 接口表示所有的 HTML 元素。一些HTML元素直接實現(xiàn)了HTMLElement接口,其它的間接實現(xiàn)HTMLElement接口.
-
HTMLElement.offsetHeight是一個只讀屬性,它返回該元素的像素高度,高度包含該元素的垂直內(nèi)邊距和邊框,且是一個整數(shù)。通常,元素的offsetHeight是一種元素CSS高度的衡量標(biāo)準(zhǔn),包括元素的邊框、內(nèi)邊距和元素的水平滾動條(如果存在且渲染的話),不包含:before或:after等偽類元素的高度。對于文檔的body對象,它包括代替元素的CSS高度線性總含量高。浮動元素的向下延伸內(nèi)容高度是被忽略的。 如果元素被隱藏(例如 元素或者元素的祖先之一的元素的style.display被設(shè)置為none),則返回0HTMLElement.offsetWidth是一個只讀屬性,返回一個元素的布局寬度。一個典型的(譯者注:各瀏覽器的offsetWidth可能有所不同)offsetWidth是測量包含元素的邊框(border)、水平線上的內(nèi)邊距(padding)、豎直方向滾動條(scrollbar)(如果存在的話)、以及CSS設(shè)置的寬度(width)的值。

-
HTMLElement.offsetLeft是一個只讀屬性,返回當(dāng)前元素左上角相對于 HTMLElement.offsetParent 節(jié)點的左邊界偏移的像素值。對塊級元素來說,offsetTop、offsetLeft、offsetWidth 及 offsetHeight 描述了元素相對于 offsetParent 的邊界框。然而,對于可被截斷到下一行的行內(nèi)元素(如 span),offsetTop 和 offsetLeft 描述的是第一個邊界框的位置(使用 Element.getClientRects() 來獲取其寬度和高度),而 offsetWidth 和 offsetHeight 描述的是邊界框的尺寸(使用 Element.getBoundingClientRect 來獲取其位置)。因此,使用 offsetLeft、offsetTop、offsetWidth、offsetHeight 來對應(yīng) left、top、width 和 height 的一個盒子將不會是文本容器 span 的盒子邊界。HTMLElement.offsetTop為只讀屬性,它返回當(dāng)前元素相對于其 offsetParent 元素的頂部內(nèi)邊距的距離。HTMLElement.offsetParent是一個只讀屬性,返回一個指向最近的(指包含層級上的最近)包含該元素的定位元素或者最近的 table,td,th,body元素。當(dāng)元素的 style.display 設(shè)置為 "none" 時,offsetParent 返回 null。offsetParent 很有用,因為 offsetTop 和 offsetLeft 都是相對于其內(nèi)邊距邊界的。-
window屬性
window 對象表示一個包含DOM文檔的窗口,其 document 屬性指向窗口中載入的 DOM文檔 。使用 document.defaultView 屬性可以獲取指定文檔所在窗口。
window作為全局變量,代表了腳本正在運行的窗口,暴露給 Javascript 代碼。
本節(jié)為 DOM Window 對象中可用的所有方法、屬性和事件提供簡要參考。window 對象實現(xiàn)了 Window 接口,此接口繼承自 AbstractView 接口。一些額外的全局函數(shù)、命名空間、對象、接口和構(gòu)造函數(shù)與 window 沒有典型的關(guān)聯(lián),但卻是有效的,它們在 JavaScript參考 和 DOM參考 中列出。
在有標(biāo)簽頁功能的瀏覽器中,每個標(biāo)簽都擁有自己的 window 對象;也就是說,同一個窗口的標(biāo)簽頁之間不會共享一個 window 對象。有一些方法,如 window.resizeTo 和 window.resizeBy 之類的方法會作用于整個窗口而不是 window 對象所屬的那個標(biāo)簽。一般而言,如果一樣?xùn)|西無法恰當(dāng)?shù)刈饔糜跇?biāo)簽,那么它就會作用于窗口。
-
Window.innerHeight瀏覽器窗口的視口(viewport)高度(以像素為單位);如果有水平滾動條,也包括滾動條高度。Window.innerWidth瀏覽器視口(viewport)寬度(單位:像素),如果存在垂直滾動條則包括它。Window.outerHeightWindow.outerHeight 獲取整個瀏覽器窗口的高度(單位:像素),包括側(cè)邊欄(如果存在)、窗口鑲邊(window chrome)和窗口調(diào)正邊框(window resizing borders/handles)Window.outerWidth獲取瀏覽器窗口外部的寬度。表示整個瀏覽器窗口的寬度,包括側(cè)邊欄(如果存在)、窗口鑲邊(window chrome)和調(diào)正窗口大小的邊框(window resizing borders/handles)。-

Window.screenLeft只讀屬性返回瀏覽器左邊框到左邊屏幕邊緣的距離,單位是css的像素。Window.screenTop只讀屬性返回垂直距離,單位是CSS 像素, 從用戶瀏覽器的上邊界到屏幕最頂端。Window.screenX返回瀏覽器左邊界到操作系統(tǒng)桌面左邊界的水平距離。Window.screenY返回瀏覽器頂部距離系統(tǒng)桌面頂部的垂直距離。Window.scrollX返回文檔/頁面水平方向滾動的像素值。pageXOffset 屬性是 scrollY 屬性的別名Window.scrollY返回文檔在垂直方向已滾動的像素值。pageYOffset 屬性是 scrollY 屬性的別名
-
-
screen屬性
-
Screen 接口表示一個屏幕窗口,往往指的是當(dāng)前正在被渲染的window對象,可以使用 window.screen 獲取它。
Screen.availTop瀏覽器窗口在屏幕上的可占用空間上邊距離屏幕上邊界的像素值。Screen.availLeft返回瀏覽器可用空間左邊距離屏幕(系統(tǒng)桌面)左邊界的距離。Screen.availHeight返回瀏覽器窗口在屏幕上可占用的垂直空間,即最大高度。Screen.availWidth返回瀏覽器窗口可占用的水平寬度(單位:像素)。Screen.height返回屏幕的高度(單位:像素)。Screen.width返回屏幕的寬度。
來源:https://www.jb51.net/javascript/317197v56.htm
浙公網(wǎng)安備 33010602011771號