在做一些元件和互動時,常常需要動態獲取滑鼠點選位置、元素寬高和元素位置資訊,網上有很多種方法,但自己沒有總結過,不知道各種方法的優缺點和相容性,在此專門的總結一下。
注意:
- 這些關於視覺的內容都被定義在了 W3C 的 CSSOM View Module 模組中,裡面有詳細的介面定義和說明,建議好好研讀。
- 本文主要參照 W3C 文件全面瞭解各個屬性的意義,對應介面文件用圖文的方式直觀顯示各個屬性的含義。但也會有一些自己沒有完全理解和錯誤之處,請各位批評指正,後續會繼續完善。
- 本文涉及到圖片較多,為了獲得最佳體驗,建議使用電腦閱讀。
閱讀 W3C 規範的總結
Extensions to the Window Interface
data:image/s3,"s3://crabby-images/dcd72/dcd72355d0b486df72d0c0bc4177211c103311b2" alt="用 js 獲取頁面元素的位置圖文總結"
圖片糾錯: scrollX = pageXOffset:表示滾動條在X軸方向上滾動的距離;scrollY = pageYOffset:表示滾動條在Y軸方向上滾動的距離
data:image/s3,"s3://crabby-images/98e49/98e49812935eedd8f34ecb17d411af7d69cbac59" alt="用 js 獲取頁面元素的位置圖文總結"
The Screen Interface
data:image/s3,"s3://crabby-images/7cbaf/7cbafd3d5c345614f2e556b2716ea5f920bf36aa" alt="用 js 獲取頁面元素的位置圖文總結"
data:image/s3,"s3://crabby-images/2d969/2d969de730b8889b31d4f1574a5a6456b7d1ea80" alt="用 js 獲取頁面元素的位置圖文總結"
Extensions to the Document Interface
data:image/s3,"s3://crabby-images/f258e/f258e1b7025863f4b9705272b67661d02f1ce293" alt="用 js 獲取頁面元素的位置圖文總結"
Extensions to the Element Interface
data:image/s3,"s3://crabby-images/2efc3/2efc3c8da06e8028a5e7a820d81eb141a396a049" alt="用 js 獲取頁面元素的位置圖文總結"
data:image/s3,"s3://crabby-images/38b4f/38b4fdc79b8eecdb2f01023ecc9823cd1664a952" alt="用 js 獲取頁面元素的位置圖文總結"
data:image/s3,"s3://crabby-images/597bc/597bc364be75cfd564123f42e16ef71b0e078851" alt="用 js 獲取頁面元素的位置圖文總結"
Extensions to the HTMLElement Interface
data:image/s3,"s3://crabby-images/60389/60389cc10bce540fb45a664cfd81600963086fa3" alt="用 js 獲取頁面元素的位置圖文總結"
data:image/s3,"s3://crabby-images/c4897/c489727f3151af0fc628d382adcc31e063973308" alt="用 js 獲取頁面元素的位置圖文總結"
Extensions to the HTMLImageElement Interface
data:image/s3,"s3://crabby-images/26abc/26abcb9daca94c6ff117407aef4070fbca63c644" alt="用 js 獲取頁面元素的位置圖文總結"
Extensions to the Range Interface
data:image/s3,"s3://crabby-images/0d36a/0d36a8948fde89dae8e397658b206fd8964d33aa" alt="用 js 獲取頁面元素的位置圖文總結"
getBoundingClientRect()返回物件的屬性
data:image/s3,"s3://crabby-images/0e1aa/0e1aaff4d4106155005b7b11115a7c645e8aa6b0" alt="用 js 獲取頁面元素的位置圖文總結"
Extensions to the MouseEvent Interface
data:image/s3,"s3://crabby-images/5f972/5f972a6edceba78073a91ab72f0635697971b51d" alt="用 js 獲取頁面元素的位置圖文總結"
data:image/s3,"s3://crabby-images/e2e7c/e2e7cca8c87cfb9a8f70b8f9ebe0ec4de8e45a30" alt="用 js 獲取頁面元素的位置圖文總結"
希望對你有幫助,歡迎分享和批評指正~~~~~