大家好,又见面了,我是你们的朋友全栈君。
offsetwidth是包括border、padding等,即盒模型尺寸。(所以遇到offsetWidth和border同时出现的时候要考虑一下会不会导致出错)
一个小实验
当div宽高200px,border为1px的时候,在给div添加一个变窄的定时器事件的时候,使用语句:div.style.width = div.offfsetWidth -1+‘px’,会发现,div在变宽。
究其原因:style.width为200是毋庸置疑的,可是,offsetWidth却是(200+1+1)=202,所以在第一次语句执行之后,style.width = 202-1+‘px’=201px;这就是div变宽的原因,接下来的第二次第三次执行以此类推。
解决:①比较繁琐的一个解决方法,是在div的行间样式中设置width,然后在赋值语句中的右边改成parseInt(div.style.width),也可以完成功能实现。
②通过封装获取style的方法,当有行间样式的时候就获取行间的数据,当在样式表中则获取样式表中width的值
function getStyle(obj,name){ //包了一个函数,解决不同浏览器的兼容性问题
if(obj.currentStyle){
return obj.currentStyle[name]; //currentStyle只兼容IE,不兼容火狐和谷歌
}else{
return getComputedStyle(obj,false)[name];//getComputedStyle是兼容火狐谷歌,不兼容IE
//JS运动应用-1
}
}
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/129592.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...