前端中的 Attribute & Property
为了在翻译上显示出区别,Attribute一般被翻译为特性,Property被译为属性。
在使用上面,Angular已经表明态度
Template binding works with properties and events, not attributes.
模板绑定是通过 property 和事件来工作的,而不是 attribute。
jQuery中的prop()和attr()如何选择,众说纷纭...
两种主流观点:
- 对于一些公认的attribute和property,使用
setAttribute(),理由是property会出现class映射过去为className,名称不统一的问题。 - 红宝书作者推荐操作DOM property,因为在浏览器上面表现的比较一致。
HTML attribute & DOM property 关系与区别
引用Angular文档中的一段话去概括两者的关系和区别:
HTML attribute 与 DOM property 的对比
attribute 是由 HTML 定义的。property 是由 DOM (Document Object Model) 定义的。
少量 HTML attribute 和 property 之间有着 1:1 的映射,如id。
有些 HTML attribute 没有对应的 property,如colspan。
有些 DOM property 没有对应的 attribute,如textContent。
普遍原则:
- HTML attribute 初始化 DOM property,然后它们的任务就完成了。
- 更改 attribute 的值,相当于再次初始化DOM property 。
- 更改 property 的值,property值改变,attribute值不变。
几个有代表性的映射表
| HTML attribute | DOM property |
|---|---|
| id | id |
| class | className |
| checked = 'checked' | checked 值为true |
普遍原则失效的情况
为什么说是普遍原则呢?在低版本的ie中,操作DOM property中的value,attribute中的value也发生了改变。完全不讲道理 - -
<input type="text" value="123" id="myInput">
更改HTML attribute
myInput.setAttribute('value', 'test Attr');
| 浏览器 | myInput.getAttribute('value') | myInput.value |
|---|---|---|
| chrome ie11 ff | test Attr | test Attr |
| ie8 | test Attr | test Attr |
更改DOM property
document.getElementById('myInput').value = 'test property';
| 浏览器 | myInput.getAttribute('value') | myInput.value |
|---|---|---|
| chrome ie11 ff | 123 | test property |
| ie8 | test property (普遍原则下应该为123) | test property |
prop()和attr()的选择
prop()采用的是更改DOM property的方式,基本上对应更改DOM属性。
| 原生DOM | jQuery | 操作 |
|---|---|---|
| element.value | $element.prop( name[,value]) | 读写 |
| delete element.propertyName | $element.removeProp( propertyName ) | 删除 |
attr()采用的是更改HTML attribute的方式,基本上对应DOM中提供的三个操作attribute的方法。
| 原生DOM | jQuery | 操作 |
|---|---|---|
| element.getAttribute(name) | $element.attr(name) | 读 |
| element.setAttribute(name,value) | $element.attr(name ,value) | 写 |
| delete element.removeAttribute(name) | $element.removeAttr( name ) | 删除 |
小结
- 获取一些标签上面的的自定义属性,或者一些基本不会改变的特性的时候,多数情况下用
attr()(data-*等除外)。
<form action="test.php" user-my-name="nilinli" method="post"></form>
$('form').attr('user-my-name'); // nilinli
$('form').attr('action'); // test.php
- 其他情况下,操作DOM与页面交互,一般情况下用
prop() - 总的来说,尽量操作DOM property,只有在没有DOM property(自定义attribute或者没有相关映射),才去操作HTML attribute。
前端中的 Attribute & Property的更多相关文章
- C#中的Attribute Property区别
Attribute 一般译作"特性",Property 仍然译为"属性". Attribute 是一种可由用户自由定义的修饰符(Modifier),可以用来修饰 ...
- HTML中的attribute和property
一.概述 attribute和property是常常被弄混的两个概念. 简单来说,property则是JS代码里访问的: document.getElementByTagName('my-elemen ...
- 浅析C#中的Attribute(转)
最近用到了,所以静下心来找些资料看了一下,终于把这东西搞清楚了. 一.什么是Attribute 先看下面的三段代码: 1.自定义Attribute类:VersionAttribute [Attribu ...
- 关于C# 中的Attribute 特性
关于C# 中的Attribute 特性 作者: 钢钢 来源: 博客园 发布时间: 2011-01-09 23:30 阅读: 13921 次 推荐: 12 原文链接 [收藏] 摘要:纠结地说 ...
- C#中的Attribute
最近用到了,所以静下心来找些资料看了一下,终于把这东西搞清楚了. 一.什么是Attribute 先看下面的三段代码: 1.自定义Attribute类:VersionAttribute [Attribu ...
- Element link doesn't have required attribute property
前端标准http://validator.w3.org/ 拒绝你的代码时报 Element link doesn't have required attribute property 把样式链接 &l ...
- 浅析C#中的Attribute
原文地址:http://www.cnblogs.com/hyddd/archive/2009/07/20/1526777.html 一.什么是Attribute 先看下面的三段代码: 1.自定义Att ...
- C#中的Attribute详解(下)
原文地址:https://blog.csdn.net/xiaouncle/article/details/70229119 C#中的Attribute详解(下) 一.Attribute本质 从上篇里我 ...
- 说说移动前端中 viewport (视口)
转载网络资源的文章:来源不详~~ 移动前端中常说的 viewport (视口)就是浏览器显示页面内容的屏幕区域.其中涉及几个重要概念是 dip ( device-independent pixel 设 ...
随机推荐
- EntityFramework学习要点记一
一.Entity的注解属性(Annotations)不管是code first还是db first,都需要用到注解属性,至于用System.ComponentModel.DataAnnotations ...
- O031、Start Instance 操作详解
参考https://www.cnblogs.com/CloudMan6/p/5470723.html 本节将通过日志文件分析 instance start 的操作过程,下面是 start inst ...
- Redis-List常用命令
Redis-List常用命令 lpush key value- 将指定value推到指定key的最左端.假如有 key1 对应值为 1 2 3,现在lpush key1 4,将4推到队列的最左端,那么 ...
- 什么是NoSQL,为什么要使用NoSQL?
详见: https://blog.csdn.net/a909301740/article/details/80149552 https://baike.so.com/doc/5569749-57849 ...
- XML基础综合案例【三】
实现简单的学生管理系统 使用xml当做数据,存储学生信息 ** 创建一个xml文件,写一些学生信息 ** 增加操作1.创建解析器2.得到document 3.获取到根节点4.在根节点上面创建stu标签 ...
- 在STM32上如果不使用外部晶振,OSC_IN和OSC_OUT的接法
如果使用内部RC振荡器而不使用外部晶振,请按照下面方法处理: 1)对于100脚或144脚的产品,OSC_IN应接地,OSC_OUT应悬空.2)对于少于100脚的产品,有2种接法: 2.1)OSC_I ...
- php的加解密openssl_encrypt与openssl_decrypt
https://blog.csdn.net/zhemejinnameyuanxc/article/details/83383434 php的加解密
- WCF契约定义及主要用途
我们在使用WCF时,对其制定各种各样的规则,就叫做WCF契约.任何一个分布式的应用程序在传递消息的时候都需要实现制定一个规则. WCF配置文件相关操作技巧解析 全方位解读WCF Address配置文件 ...
- 第七章 路由 71 路由-router-link的使用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- u-boot-2018.09 DTS上 I2C节点的解析 (转)
这篇理下uboot上I2C总线挂载设备的整个流程. 其他总线(如SPI等)应是类同的思路. uboot 中,以max8997挂载到s3c24xx i2c总线为例, dts里面的写法如下 aliases ...