JS获取对象的某个CSS属性值的问题_html/css_WEB-ITnose

function getStyle(obj,attr){ if(obj.currentStyle){ return obj.currentStyle[attr]; }else{ return getComputedStyle(obj,false)[attr]; } }

该方法很强大,兼容所有浏览器,可获取对象的某个特定的CSS属性;

但是后来使用该方法时,发现在火狐和IE上有个共同的BUG,就是获取border的值时,他们都返回空了;

因为浏览器对border的渲染有差异,在火狐上border是分四个方向来渲染的,

立即学习“前端免费学习笔记(深入)”;

所以获取border的值时,要分开获取,

这样:getStyle(obj,’borderLeftWidth’) 来取得边框的值。

其实这个方法本身是没有任何问题的,只是在使用时,只是在使用时对浏览器本身的一些差异,还是要注意;

是否其他属性的值也有这种差异,还要在实际使用时去发现。

另外,该方法在获取行内样式时是不通用的,还是要用 obj.style[attr]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3116579.html

(0)
上一篇 2025年3月29日 13:14:56
下一篇 2025年3月13日 04:55:30

AD推荐 黄金广告位招租... 更多推荐

发表回复

登录后才能评论