Posted in Javascript onNovember 30, 2011
这个比较简单,做个记录而已。
创建一个嵌套节点,让外层节点产生滚动条,然后用offsetWidth - clientWidth即可获得滚动条宽度。需要注意的是为了避免页面抖动,可以设置外层元素position:absolute和visibility:hidden
参考:
function getScrollWith(){ var wrap = setAttributes(document.createElement('div'),{ style : { width : '200px', height: '200px', overflow: 'auto', position:'absolute', visibility:'hidden' } }) var inner = setAttributes(document.createElement('div'),{ style : { width : '100px', height: '2000px' } }) document.body.appendChild(wrap); wrap.appendChild(inner); var w = wrap.offsetWidth - wrap.clientWidth; document.body.removeChild(wrap); wrap = null; inner = null; return w; } function setAttributes(elem,opts){ for(var key in opts){ if(typeof opts[key] == 'string'){ elem[key] = opts[key]; }else{ if(!elem[key]){ elem[key] = {}; } setAttributes(elem[key],opts[key]); } } return elem; }
js取滚动条的尺寸的函数代码
声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@