offsetWidth、clientWidth、width、scrollWidth區別及js與jQuery擷取的方式

來源:互聯網
上載者:User

標籤:htm   方式   padding   document   技術交流   code   add   doctype   溢出   

<!DOCTYPE html><html><head><meta charset="UTF-8"><title>offsetWidth、clientWidth、width、scrollWidth區別及js與jQuery擷取的方式</title><script type="text/javascript" src="jquery.min.js"></script></head><body style="border:1px solid #ccc">        <div id="div" style="width:100px;height:80px;left:10px;top:8px;position:relative;border:1px solid #ccc;margin:20px 10px;padding:7px 6px;">        </div>    <script type="text/javascript">        var divObj = document.getElementById("div");        var dOffsetWidth = divObj.offsetWidth;//返回元素的寬度(包括元素寬度、內邊距和邊框,不包括外邊距)        var $dOffsetWidth = $(divObj).outerWidth(false);//參數為true,包括外邊距        var dOffsetHeight = divObj.offsetHeight;//返回元素的高度(包括元素高度、內邊距和邊框,不包括外邊距)        var $dOffsetHeight = $(divObj).outerHeight(false);//參數為true,包括外邊距        var dClientWidth = divObj.clientWidth;//返回元素的寬度(包括元素寬度、內邊距,不包括邊框和外邊距)        var $dClientWidth = $(divObj).innerWidth();        var dClientHeight = divObj.clientHeight;//返回元素的高度(包括元素高度、內邊距,不包括邊框和外邊距)        var $dClientHeight = $(divObj).innerHeight();        var dWidth = divObj.style.width;//返回元素的寬度(包括元素寬度,不包括內邊距、邊框和外邊距)        var $dWidth = $(divObj).width();//width(val)設定寬        var dHeight = divObj.style.height;//返回元素的高度(包括元素高度,不包括內邊距、邊框和外邊距)        var $dHeight = $(divObj).height();//height(val)設定高        var dscrollWidth = divObj.scrollWidth;//返回元素的寬度(包括元素寬度、內邊距和溢出尺寸,不包括邊框和外邊距),無溢出的情況,與clientWidth相同        var dscrollHeight = divObj.scrollHeight;//返回元素的高度(包括元素高度、內邊距和溢出尺寸,不包括邊框和外邊距),無溢出的情況,與clientHeight相同        console.log("dOffsetWidth:"+dOffsetWidth+",dOffsetHeight:"+dOffsetHeight+",dClientWidth:"+dClientWidth+",dClientHeight:"+dClientHeight+",dWidth:"+dWidth+",dHeight:"+dHeight+",dscrollWidth:"+dscrollWidth+",dscrollHeight:"+dscrollHeight);        console.log("$dOffsetWidth:"+$dOffsetWidth+",$dOffsetHeight:"+$dOffsetHeight+",$dClientWidth:"+$dClientWidth+",$dClientHeight:"+$dClientHeight+",$dWidth:"+$dWidth+",$dHeight:"+$dHeight);        /*            注意:offsetWidth(offsetHeight)與style.width(style.height)的區別            1. style.height 返回的是字串,如28px,offsetWidth返回的是數值28,如果需要對取得的值進行計算,用offsetWidth比較方便;如果拿到offsetWidth設定style.left的值,需加‘px‘。            2. style.width/style.height與scrollWidth/scrollHeight是可讀寫的屬性,clientWidth/clientHeight與offsetWidth/offsetHeight是唯讀屬性            3. style.height的值需要事先定義,否則取到的值為空白。而且必須要定義在html裡,如果定義在css裡,style.height的值仍然為空白,但元素位移有效;而offsetWidth則仍能取到。        */        /*            總結:            1、通過style.width(style.height)或者jQuery的$(divObj).width()/$(divObj).height()擷取/設定元素的寬高            2、若要擷取元素包含邊框的寬度,則可通過divObj.offsetWidth/divObj.offsetHeight或jQuery的$(divObj).outerWidth(false)/$(divObj).outerHeight(false)擷取            3、通過$(divObj).outerWidth(true)/$(divObj).outerHeight(true)擷取帶外邊距的寬度            4、通過$(divObj).innerWidth()/$(divObj).innerHeight()擷取不包含邊框、不包含外邊距的寬度        */    </script></body></html>

技術交流QQ群:15129679

offsetWidth、clientWidth、width、scrollWidth區別及js與jQuery擷取的方式

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.