offsetWidth表示對(duì)象的可見(jiàn)寬度。
比如:
創(chuàng)新互聯(lián)公司-成都網(wǎng)站建設(shè)公司,專(zhuān)注成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、成都外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站營(yíng)銷(xiāo)推廣,申請(qǐng)域名,雅安服務(wù)器托管,網(wǎng)站托管、服務(wù)器租用有關(guān)企業(yè)網(wǎng)站制作方案、改版、費(fèi)用等問(wèn)題,請(qǐng)聯(lián)系創(chuàng)新互聯(lián)公司。
#div1 { width: 100px; height: 200px; background: red; }
結(jié)果:100
#div1 { width: 100px; height: 200px; background: red; border: 2px solid black; }
結(jié)果:104 (100 + 2 + 2)
#div1 { width: 100px; height: 200px; background: red; border: 2px solid black; padding: 20px; }
結(jié)果:144 (100 + 2 + 2 + 20 + 20)
#div1 { width: 100px; height: 200px; background: red; margin: 4px; }
結(jié)果:100
**
所以,offsetWidth = width + padding + border, 和margin無(wú)關(guān)。
**
下面來(lái)看一個(gè)例子:
offsetWidth
現(xiàn)象:紅色div逐漸變窄,直到消失,沒(méi)問(wèn)題!
如果給div加一個(gè)border,呢?
offsetWidth
現(xiàn)象:紅色div不僅沒(méi)有變窄,反而越來(lái)越寬……
*
原因也很簡(jiǎn)單:就是border的直接原因,因?yàn)閛ffsetWidth是把border算進(jìn)去的,定時(shí)器輪詢(xún)的時(shí)候,第一次,width : 102 - 1 == 101 ,那么offsetWidth立馬就變?yōu)?03;第二次,width: 103 - 1 == 102, 那么offsetWidth立馬就變?yōu)?04;緊接著第三次,width: 104 - 1 == 103, offsetWidth就為104了……
倘若把 oDiv.style.width = oDiv.offsetWidth - 1 + ‘px'; 換成 -2,那么紅色div就不動(dòng)了,不會(huì)變寬也不會(huì)變窄,因?yàn)閛ffsetWidth為102,減去2就是100和原本的width相等,下一次循環(huán),offsetWidth就等于100加上border的2,再減去2還是100,所以不動(dòng)……*
解決方案也很簡(jiǎn)單,惹不起還躲不起?不用offsetWidth了!
我們都知道,獲取元素的行間樣式直接用element.style.width即可,但是這只針對(duì)元素的行間樣式,如果寫(xiě)在css中,你就獲取不到了.
但也是有辦法的:
offsetWidth
有了上面的這個(gè)封裝,我們就可以解決offsetWidth帶來(lái)的困擾了
offsetWidth
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。