JavaScript中offsetWidth的bug及解決方法
offsetWidth表示對(duì)象的可見(jià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è)例子:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>offsetWidth</title>
<style type="text/css">
#div1 {
width: 500px;
height: 200px;
background: red;
}
</style>
</head>
<body>
<div id="div1"></div>
<script type="text/javascript">
var oDiv = document.getElementById('div1');
setInterval(function() {
oDiv.style.width = oDiv.offsetWidth - 1 + 'px';
}, 50);
</script>
</body>
</html>
現(xiàn)象:紅色div逐漸變窄,直到消失,沒(méi)問(wèn)題!
如果給div加一個(gè)border,呢?
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>offsetWidth</title>
<style type="text/css">
#div1 {
width: 500px;
height: 200px;
background: red;
border: 1px solid black;
}
</style>
</head>
<body>
<div id="div1"></div>
<script type="text/javascript">
var oDiv = document.getElementById('div1');
setInterval(function() {
oDiv.style.width = oDiv.offsetWidth - 1 + 'px';
}, 50);
</script>
</body>
</html>
現(xiàn)象:紅色div不僅沒(méi)有變窄,反而越來(lái)越寬……
*
原因也很簡(jiǎn)單:就是border的直接原因,因?yàn)閛ffsetWidth是把border算進(jìn)去的,定時(shí)器輪詢的時(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中,你就獲取不到了.
但也是有辦法的:
- IE中用element.currentStyle.width / element.currentStyle.[‘width'];
- 非IE中用getComputedStyle(element, false)[‘width']
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>offsetWidth</title>
<style type="text/css">
#div1 {
width: 500px;
height: 200px;
background: red;
border: 1px solid black;
}
</style>
</head>
<body>
<div id="div1"></div>
<script type="text/javascript">
var oDiv = document.getElementById('div1');
function getStyle(obj, attr) {
if (obj.currentStyle) {//IE
return obj.currentStyle[attr];
} else {
return getComputedStyle(obj, false)[attr];
}
}
alert(getStyle(oDiv, 'width'));//直接彈出 “500px”
</script>
</body>
</html>
有了上面的這個(gè)封裝,我們就可以解決offsetWidth帶來(lái)的困擾了
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>offsetWidth</title>
<style type="text/css">
#div1 {
width: 500px;
height: 200px;
background: red;
border: 1px solid black;
}
</style>
</head>
<body>
<div id="div1"></div>
<script type="text/javascript">
var oDiv = document.getElementById('div1');
function getStyle(obj, attr) {
if (obj.currentStyle) {//IE
return obj.currentStyle[attr];
} else {
return getComputedStyle(obj, false)[attr];
}
}
setInterval(function() {
//parseInt是因?yàn)間etStyle()返回的是‘px'帶單位,要整數(shù)化
oDiv.style.width = parseInt(getStyle(oDiv, 'width')) - 1 + 'px';
}, 30);
</script>
</body>
</html>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js中offset,client , scroll 三大元素知識(shí)點(diǎn)總結(jié)
- MySQL查詢中LIMIT的大offset導(dǎo)致性能低下淺析
- JS中offset和勻速動(dòng)畫(huà)詳解
- js獲取元素的偏移量offset簡(jiǎn)單方法(必看)
- 詳解原生js實(shí)現(xiàn)offset方法
- div的offsetLeft與style.left區(qū)別
- JavaScript中style.left與offsetLeft的使用及區(qū)別詳解
- window.setInterval()方法的定義和用法及offsetLeft與style.left的區(qū)別
- springboot中如何實(shí)現(xiàn)kafa指定offset消費(fèi)
相關(guān)文章
JavaScript面向?qū)ο笾叽蠡驹瓌t實(shí)例詳解
這篇文章主要介紹了JavaScript面向?qū)ο笾叽蠡驹瓌t,結(jié)合實(shí)例形式詳細(xì)分析了JavaScript面向?qū)ο笃叽蠡驹瓌t,包括單一職責(zé)、開(kāi)閉原則、里氏替換、依賴倒置、接口隔離、迪米特法則及組合/聚合復(fù)用原則,需要的朋友可以參考下2020-05-05
JS冷知識(shí)之不起眼但有用的String.raw方法
String.raw是JavaScript中模板字符串的一個(gè)標(biāo)簽函數(shù),它的作用是將模板字符串不轉(zhuǎn)義的原始字符串內(nèi)容返回,接下來(lái)通過(guò)本文給大家介紹JS冷知識(shí)之不起眼但有用的String.raw方法,需要的朋友可以參考下2022-06-06
JS實(shí)現(xiàn)為表格動(dòng)態(tài)添加標(biāo)題的方法
這篇文章主要介紹了JS實(shí)現(xiàn)為表格動(dòng)態(tài)添加標(biāo)題的方法,涉及javascript中createCaption方法添加標(biāo)題的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
JS判斷字符串長(zhǎng)度的5個(gè)方法(區(qū)分中文和英文)
這篇文章主要介紹了JS判斷字符串長(zhǎng)度的5個(gè)方法,并且區(qū)分中文和英文,需要的朋友可以參考下2014-03-03
一文詳解JavaScript中的事件循環(huán)(event?loop)機(jī)制
JavaScript中的事件循環(huán)(Event?Loop)是一種重要的機(jī)制,用于管理異步代碼的執(zhí)行,它確保?JavaScript?單線程環(huán)境中的任務(wù)按照正確的順序執(zhí)行,同時(shí)允許異步操作如定時(shí)器、網(wǎng)絡(luò)請(qǐng)求和事件處理,本將給大家詳細(xì)的介紹一下JavaScript事件循環(huán)機(jī)制,感興趣的朋友可以參考下2023-12-12
基于JavaScript實(shí)現(xiàn)輪播圖原理及示例
這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)輪播圖原理及示例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02

