js取捲軸的尺寸執行個體代碼

來源:互聯網
上載者:User

標籤:style   blog   class   code   c   java   

分享一個js取捲軸的尺寸的函數代碼,很簡單,很實用。

建立一個嵌套節點,讓外層節點產生捲軸,然後用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; } www.jbxue.comfunction 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; }

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.