在做一些组件和交互时,常常需要动态获取鼠标点击位置、元素宽高和元素位置信息,网上有很多种方法,但自己没有总结过,不知道各种方法的优缺点和兼容性,在此专门的总结一下。
Note: 这些关于视觉的内容都被总结在了 W3C 的 CSSOM View Module 模块中,里面有详细的接口定义和说明,建议好好研读。
阅读 W3C 规范的总结
Extensions to the Window Interface
data:image/s3,"s3://crabby-images/7e273/7e273ed1fc56e7aa27a42dba08918ca7b85bfa39" alt=""
图片纠错: scrollX = pageXOffset:表示滚动条在X轴方向上滚动的距离;scrollY = pageYOffset:表示滚动条在Y轴方向上滚动的距离
data:image/s3,"s3://crabby-images/84cbb/84cbbfd6559d3588cceb92008e27af0653ed92b2" alt=""
The Screen Interface
data:image/s3,"s3://crabby-images/a8e74/a8e747155c96d99a32f6c3e6779903f338170894" alt=""
data:image/s3,"s3://crabby-images/6ed3f/6ed3f4c75b3e33e8b53b77f73add517dfecf6a81" alt=""
Extensions to the Document Interface
data:image/s3,"s3://crabby-images/8221d/8221d39aa67ae736040ad6fb117b4dfece55ed79" alt=""
Extensions to the Element Interface
data:image/s3,"s3://crabby-images/6e765/6e765eddebcf21ed12eaf3461cbac4ca0cebdd61" alt=""
data:image/s3,"s3://crabby-images/3c3cd/3c3cd25d56f86bab0d145e010be49ac49a2f999a" alt=""
data:image/s3,"s3://crabby-images/cb765/cb76516b501647620e2ec58ac299956daafbc919" alt=""
Extensions to the HTMLElement Interface
data:image/s3,"s3://crabby-images/d319f/d319f90e687cf7d3666c76e81a4f325625be6534" alt=""
data:image/s3,"s3://crabby-images/4d2a5/4d2a558e9ff95471ac7bac6f10df18369ff0e708" alt=""
Extensions to the HTMLImageElement Interface
data:image/s3,"s3://crabby-images/9c7cc/9c7ccfe410f18666efb5e69b06af00949368d6e6" alt=""
Extensions to the Range Interface
data:image/s3,"s3://crabby-images/aa7ab/aa7abf830cea4a3b591bf1c4da8f530fa25dd975" alt=""
data:image/s3,"s3://crabby-images/c0032/c0032ce9129fc8383f020b62bec8162ba9ccdd4f" alt=""
Extensions to the MouseEvent Interface
data:image/s3,"s3://crabby-images/bade5/bade5734806b1df40323ba7ee3c1c013af1982e1" alt=""
data:image/s3,"s3://crabby-images/ff8c6/ff8c65fe7cf1f97de0deef1f817c94472d95df25" alt=""