DOM中 property 和 attribute 详解

时间:2022-03-01 03:47:41

被问到 property 和 attribute 的区别,想来也是要好好看一下。

一、基本概念区别

其实Attribute和Property这两个单词,翻译出来都是“属性”,《js高级程序设计》书中翻译为“特性”和“属性”,以示区别。从而我们也可以顾名思义

特性vs属性(当然平时也可以简单的说两者都是属性),可以这样认为:

Attribute

是HTML标签上的某个属性(特性),如‘type’,'id','value','class'以及自定义属性,它的值只能是字符串。

Property

javascript获取到的DOM节点对象,比如a 你可以将他看作为一个基本的js对象,这个节点对象包括很多属性((property),比如“value”,“className”)

以及一些方法,setAttribute,getAttribute,onclick等

还是太生涩了?看个input的例子

<input type="text" name="age" class="age" id="age" value="17" myAttr="myAttr">

DOM中 property 和 attribute 详解

可以看到,attributes只是properties这个大货色中的某个属性,其余property也是这样(和attributes同级)

再来看看attributes这货长什么样?

DOM中 property 和 attribute 详解

ok那我们可以直接这样玩了

也许是因为class是js的保留字,不能直接age.class吧,用className代替这几种方式分别获取了attribute和property

DOM中 property 和 attribute 详解

但是我们的自定义属性,就有不同了

DOM中 property 和 attribute 详解

常用的Attribute,例如id、class、name等,已经被作为Property附加到DOM对象上,可以和Property一样取值和赋值。但是自定义的Attribute,就不会有这样的特殊优待

attribute的获取设置修改一般使用 setAttribute()和getAttribute()  比较方便

而property 则使用  打点符. 或 [] 的方式获取即可

二、一些息息相关又有差异的东东

1. value的差异

默认情况下是17

DOM中 property 和 attribute 详解

DOM中 property 和 attribute 详解

手动或直接代码更改value为15后(可以看出输入框value的变化只会引起property方面的变化)

DOM中 property 和 attribute 详解

DOM中 property 和 attribute 详解

那主动权换为attribute呢?

DOM中 property 和 attribute 详解

2. name , id, class (互相影响)

DOM中 property 和 attribute 详解

同样的,让attribute来主动

DOM中 property 和 attribute 详解

class的操作

DOM中 property 和 attribute 详解

3.上面都是在原有属性改来改去,那增添新的属性会怎样呢?

abc,cba是可以认为是一个非默认属性吧,title,align 是,看下结果慢慢领会

DOM中 property 和 attribute 详解

把主动权交给attribute

DOM中 property 和 attribute 详解

所以一般对于默认的自有属性而言,property和attribute的影响是双向的

事实上value这东西真的很... 假设我最初没有value,会发生什么呢?

<input type="text" name="age" class="age" id="age" myAttr="myAttr">

DOM中 property 和 attribute 详解

所以啊,这是个特例,要想attribute的value也能得到变化,还非得特地去setAttribute()才行

4.对于形如 hidden:true的属性

高能预警:看这个东西会死很多脑细胞..(我的建议是跳过这段吧)

可以发现,若初始

DOM中 property 和 attribute 详解

假如我一开始input就设置了hidden呢?

<input type="text" name="age" class="age" id="age" myAttr="myAttr" hidden>

DOM中 property 和 attribute 详解

DOM中 property 和 attribute 详解

是不是很绕啊~~~~~~

那假如我一开始就给hidden来个属性呢,比如 no_hidden?(这样输入框也是会直接隐藏的)

<input type="text" name="age" class="age" id="age" myAttr="myAttr" hidden="no_hidden">

我们来看看操作

DOM中 property 和 attribute 详解

DOM中 property 和 attribute 详解

还有一种情况额,假如我设置为 hidden=true呢

<input type="text" name="age" class="age" id="age" myAttr="myAttr" hidden=true>

DOM中 property 和 attribute 详解

DOM中 property 和 attribute 详解

基本没其他情况了吧,总结一下? 好难总结,还是算了..

5. style属性

<input type="text" name="age" class="age" id="age" myAttr="myAttr" style="width:50%;height:30px;">

对于这其中的style Attribute和property的返回有什么不同呢? Attribute照常是字符串,而property则是个对象

DOM中 property 和 attribute 详解

6. onclick属性

<input type="text" name="age" class="age" id="age" myAttr="myAttr" onclick="function(){}">

Attribute可以正确获取到,而property方式就只能作为事件处理机制(所以会报错),也许也可以将其归入自定义属性的行列

DOM中 property 和 attribute 详解

7. src 或 href 这些有链接形式的属性

<img src="./1.jpg" id="img">

获取的时候,Attribute会直接使用表面上的属性(相对路径),property则会使用实际的绝对路径(设置的时候可以用相对)

DOM中 property 和 attribute 详解

三、来个小小的总结

1.没有非常明确的区别,只是有某些规律可遵循

2.attributes是和每个Property是在同一父级(可以这样认为吧)的,而每个Attribute的父级就是attributes

3. Attribute可以理解为特性(就是说可以有自定义的属性),property可以理解为属性(即html最基本提供的属性)

4.一般来说,无论开始还是任何时候,Attribute的变化会引起Property的变化, 而property的变化也会同步给Attribute进行变化(value除外)

5.有一些特殊的属性,要特殊对待

6.为了统一,最好直接使用 setAttribute()和getAttribute() ,IE8以上都支持了,不过IE6/7不支持的话,

比如obj.setAttribute("style","z-index:999;cursor:pointer")不支持,

那就退化成obj.style.cssText="z-index:999;cursor:pointer";

7.jq提供的 attr()和prop()方法, 其实就是基于 Attribute和property原生的使用方式

DOM中 property 和 attribute 详解的更多相关文章

  1. DOM 中 Property 和 Attribute 的区别

    原文地址:http://web.jobbole.com/83129/ property 和 attribute非常容易混淆,两个单词的中文翻译也都非常相近(property:属性,attribute: ...

  2. DOM 中 Property 和 Attribute 的区别(转)

    property 和 attribute非常容易混淆,两个单词的中文翻译也都非常相近(property:属性,attribute:特性),但实际上,二者是不同的东西,属于不同的范畴. property ...

  3. &lbrack;转&rsqb;DOM 中 Property 和 Attribute 的区别

    angular的文档: https://angular.io/guide/template-syntax#property-binding https://blog.csdn.net/sunq1982 ...

  4. Objective-C中&commat;property的所有属性详解

    1,assign : 简单赋值,不更改索引计数 假设你用malloc分配了一块内存,并且把它的地址赋值给了指针a,后来你希望指针b也共享这块内存,于是你又把a赋值给(assign)了b.此时a 和b指 ...

  5. C&num;中的Attribute详解(下)

    原文地址:https://blog.csdn.net/xiaouncle/article/details/70229119 C#中的Attribute详解(下) 一.Attribute本质 从上篇里我 ...

  6. &period;Net Attribute详解&lpar;一&rpar;

    .Net Attribute详解(一) 2013-11-27 08:10 by JustRun, 1427 阅读, 14 评论, 收藏, 编辑 Attribute的直接翻译是属性,这和Property ...

  7. 巨人大哥谈Web应用中的Session&lpar;session详解&rpar;

    巨人大哥谈Web应用中的Session(session详解) 虽然session机制在web应用程序中被采用已经很长时间了,但是仍然有很多人不清楚session机制的本质,以至不能正确的应用这一技术. ...

  8. &period;Net Attribute详解&lpar;下&rpar; - 使用Attribute武装枚举类型

    接上文.Net Attribute详解(上)-Attribute本质以及一个简单示例,这篇文章介绍一个非常实用的例子,相信你一定能够用到你正在开发的项目中.枚举类型被常常用到项目中,如果要使用枚举To ...

  9. JS中的event 对象详解

    JS中的event 对象详解   JS的event对象 Event属性和方法:1. type:事件的类型,如onlick中的click:2. srcElement/target:事件源,就是发生事件的 ...

随机推荐

  1. android性能测试与调优:使用 DDMS 查看内存分配情况

    1. 启用自己的APK后 2. 点击左边更新heap 3. 点击右边的heap中的垃圾回收cause GC,等待数秒出现回收内存与数据情况(由于内存回收了APK运行出现异常crash) 4. 点击一个 ...

  2. WinStore控件之Button

    1 Buton入门简单应用 <StackPanel > <Button Content="按钮1" Height="80" Name=&quo ...

  3. CSS——元素分类

    1.标签元素被分为三大类:块状元素.内联元素和内联块元素. (1)常见块状元素有:<div>.<p>.<h1>...<h6>.<ol>.&l ...

  4. (六) JavaScript 对象

  5. Session丢失的解决方法

    1.修改配置文件 <sessionState mode="StateServer" stateConnectionString="tcpip=127.0.0.1:4 ...

  6. MySQL的keepalived高可用监控脚本

    MySQL的keepalived高可用监控脚本 MySQL(或者其它服务)的keepalived高可用监控脚本 开发脚本需求 :我们知道,keepalive是基于虚拟ip的存活来判断是否抢占maste ...

  7. Hibernate实例二

    Hibernate实例二 一.测试openSession方法和getCurrentSession方法 hebernate中可以通过上述两种方法获取session对象以对数据库进行操作,下面的代码以及注 ...

  8. PHP qq第三方登录,install时,报Not Found

    最近在学习qq的第三方登录,先在慕课网中观看了相关视频,懂了原理. 然后进行操作时,在下载好SDK后,在../install/install.html中,配置了相关的openid,oppkey,cal ...

  9. &lbrack;na&rsqb;pc加入域认证细节

    这也是以前好奇,因为学生时候,经常机房上网, 对一些譬如.. 现在看来很low了. 是小作坊式的技术, 真正上不了台面的.扛不住生产的压力. ftp共享 计算机统一管理等 无盘/网克等特别好奇 计算机 ...

  10. Nmap介绍

    1.Nmap介绍 Nmap用于列举网络主机清单.管理服务升级调度.监控主机或服务运行状况.Nmap可以检测目标机是否在线.端口开放情况.侦测运行的服务类型及版本信息.侦测操作系统与设备类型等信息. 1 ...