我自己在各种浏览器(IE6到chrome)测试的结果是一样,没发现什么区别
是完全一样吗?
============================
我知道大概区别了,下面第二句在高级浏览器下面查不到信息
不过我想问的是,为什么在IE6/7下第二句也可以成功执行???
是否说在ie6/7下aaa.style和aaa.getAttribute('style')等价???
alert(aaa.style.height);
alert(aaa.getAttribute('style').height);
回复内容:
路过
这是个老问题
现在应该早就不提了吧
懒的再写
贴点儿老图吧
由于写的时间很早,细节上可能有变化 由于写的时间很早,细节上可能有变化
不过大致情况如此
理解下就好了
有区别
首先区分property和attribute,两个翻译成中文都可以作为属性,但是在实际上是有区别的。
在html标签里的属性称为attribute
例如:alaki
这个dom element有3个attribute:href、data-tips、data-original_title
而property是那些它被创建的时候就有的属性,例如attributes, autofocus, className, clientHeight。
特殊的是,假如
alaki
对于这个dom element来说,class不仅是attribute,同时它也是property,但是在dom.element中,只不过它叫className,这两个是绑定的。
简单来说,一些特殊的attribute将会转换为property,脚踏两条船,同样的style也是个脚踏两条船的家伙。
假如是内联样式,通过getAttribute('style')是可以获得的,但只能获取到内联样式部分属性,通过外部样式表或者内嵌样式都是无法获得的,返回值是字符串。
假如不是内联,那么getAttribute('style')返回null或者空字符串,返回哪一个取决于这个浏览器的实现 Element.getAttribute() 。
上面两种情况,dom.style都将获得完整样式属性,返回值为对象CSSStyleDeclaration
最后一个关于ie6和ie7的问题,
如图
里面有一句话 :In IE5-7, accessing the style attribute gives an object 里面有一句话 :In IE5-7, accessing the style attribute gives an object
DOM Core
在ie5-7里面,getAttribute()的实现是跟dom.style一样的效果的
@alaki 已经说得很好了,我补充下。
elem.style 和 elem.getAttribute('style') 的关系我在这个回答里提到过一点,可以参考一下:webkit内核的浏览器为什么removeAttribute('style')会失效? - 顾轶灵的回答 (里面有些链接好像失效了)
总的来说,style 的内容属性你改成啥就会保留你改后的样子,但是 IDL 属性读时会根据新的内容属性中对应的 CSS 属性来更新,写 IDL 属性时还会重新序列化内容属性以和 IDL 属性保持同步。
举个例子:
HTML:
查看更多关于js中aaa.style和aaa.getAttribute(style)等价吗,有无区别?的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did66342