经过一个demo测试这三个属性的差异。测试
说明:spa
scrollWidth:对象的实际内容的宽度,不包边线宽度,会随对象中内容超过可视区后而变大。
clientWidth:对象内容的可视区的宽度,不包滚动条等边线,会随对象显示大小的变化而改变。
offsetWidth:对象总体的实际宽度,包滚动条等边线,会随对象显示大小的变化而改变。对象
该demo就在页面中放一个textarea元素,采用默认宽高显示。cli
状况1:scroll
元素内无内容或者内容不超过可视区,滚动不出现或不可用的状况下。im
scrollWidth=clientWidth,二者皆为内容可视区的宽度。textarea
offsetWidth为元素的实际宽度。demo
状况2:img
元素的内容超过可视区,滚动条出现和可用的状况下。co
scrollWidth>clientWidth。
scrollWidth为实际内容的宽度。
clientWidth是内容可视区的宽度。
offsetWidth是元素的实际宽度。
/***************************************/
scrollTop:页面利用滚动条滚动到下方时,隐藏在滚动条上方的页面的高度;
scrollLeft:页面利用滚动条滚动到右侧时,隐藏在滚动条左侧的页面的宽度