HTML中的attribute属性和JavaScript中的property属性的区别

一、基本概念区别

  • attribute:是HTML标签上的某个属性,如id、class、value等以及自定义属性

    它的值只能是字符串,关于这个属性一共有三个相关的方法,setAttribute、getAttribute、removeAttribute;

  • property:是js获取的DOM对象上的属性值,比如a,你可以将它看作为一个基本的js对象。

    这个节点包括很多property,比如value,className以及一些方法onclik等方法。

 

 

从上图中我们可以看出,一个js对象有很多property,该集合名字为properties,properties里面有其他property以及attributies,attributies里面有很多attribute。所以attributes其实是属于property的一个子集。

 

简单理解,Attribute就是DOM节点自带的属性,HTML标签中定义的属性和值会保存该DOM对象的attributes属性里面;而Property是这个DOM元素作为对象其附加的内容,例如childNodes、firstChild等,且都是默认的基本属性,而在创建的时候,它只会创建这些基本属性,。

总结:

    1. property和attributies都是properties的子集,而每个attribute是attributies的子集;
    1. attribute可以理解为特性,可以自定义,直接在html标签上添加的和使用setAttribute添加的情况一致,即html标签添加的都是attribute属性, property则是使用xx.属性进行更改,通常来讲,更改互相影响(value除外)
    1. 当添加新的非默认属性时,是不互通的;
    1. 一些特殊属性,则需要特殊对待。

二、attribute和property的取值和赋值

1、attribute取值

《js高级程序设计》中提到,为了方便操作,建议大家用setAttribute()和getAttribute()来操作即可。

<div id="div1" class="divClass" title="divTitle" align="left" title1="divTitle1"></div>
 
 var id = div1.getAttribute("id");              
 var className1 = div1.getAttribute("class");
 var title = div1.getAttribute("title");
 var title1 = div1.getAttribute("title1");   //自定义特性
复制代码

2、attribute赋值

 div1.setAttribute('class', 'a');
 div1.setAttribute('title', 'b');
 div1.setAttribute('title1', 'c');
 div1.setAttribute('title2', 'd');
复制代码

用setAttrbute()赋值,任何Attribute都可以,包括自定义的。而且,赋值的Attribute会立刻表现到DOM元素上。

如果是标准特性,也会更新它们关联的属性的值:

注意:在使用setAttribute的时候,该函数一定接收两个参数,setAttribute(attributeName,value),无论value的值是什么类型都会编译为字符串类型。在html标签中添加属性,本质上是跟在标签里面写属性时一样的,所以属性值最终都会编译为字符串类型。

3、property取值

属性取值很简单。取任何属性的只,用“.”就可以:

 var id = div1.id;
 var className = div1.className;
 var childNodes = div1.childNodes;
 var attrs = div1.attributes;
复制代码

此处再次强调:

  • class特性在变成属性时,名字改成了“className”,因此div1.className和div1.getAttrbute('class')相同。
  • 上面代码中的div1.attributes是取的attributes这一属性,取出来保存到attrs变量中,attrs就成了一个NamedNodeList类型的对象,里面存储了若干个Attr类型。

4、property赋值

赋值和基本的js对象属性赋值一样,用“.”即可:

div1.className = 'a';
div1.align = 'center';
div1.AAAAA = true;
div1.BBBBB = [1, 2, 3];
复制代码

对属性Property可以赋任何类型的值,而对特性Attribute只能赋值字符串!

更改property和attribute其中一个值,会出现什么结果

 

 

 

由此,可得出结论:

  • property能够从attribute中得到同步;
  • attribute也会同步property上的值;
  • attribute和property之间的数据绑定是双向的;
  • 更改property和attribute上的任意值,都会将更新反映到HTML页面中。


作者:月落梅影
链接:https://juejin.im/post/6844903966187192333
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

一只特立独行的猫猫
关注 关注
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTML Attributes
u013960094的专栏
02-27 1170
HTML Attributes (case-insensitive 大小写不敏感) Attributes provide additional information about an element, always specified in the start tagAttributes come in name/value pairs like: name="value" la
HTMLpropertyattribute区别
LaiDeJi_的博客
10-29 360
HTMLpropertyattribute区别 propertyattribute区别property /* * property: * 就是js代码whc的属性值 * */ var whc = { name: "whc", height: "180" } attribute <!-- attribute: 就是html标签input的属性值 --> <input typ
一文搞懂HTML 属性Attributes)和 DOM 属性(Properties)
最新发布
gaotlantis的博客
08-15 380
HTML 属性:用于初始化元素的状态,通常是字符串类型。DOM 属性:表示元素在内存的状态,可以是任何类型,并且可以通过 JavaScript 动态地读取和修改。理解这两者的区别有助于更有效地操作和管理 HTML 元素。
【译】详解HTMLpropertyattribute区别
随风丶逆风的博客
04-22 1322
翻看Vue API文档时发现v-bind有一个修饰符.prop比较特殊: .prop - 作为一个 DOM property 绑定而不是作为 attribute 绑定。 文档还给了一个stack overflow上的问题差别在哪里?来解释,感觉高票答案通俗易懂,遂翻译一波。 译文 当编写一段HTML代码的时候,你可以在HTML标签上面定义attribute,当浏览器编译完HTML代码,会生成与...
【前端学习 - HTML(7)propertyattribute区别是什么】
weixin_60364883的博客
01-29 989
1. propertyattribute区别是什么 attributeHTML标签上的特性,它的值只能够是字符串; property是DOM属性,是JavaScript里的对象; 简单的理解就是: Attribute就是DOM节点自带的属性,例如html常用的id、class、title、align等; 而Property是这个DOM元素作为对象,其附加的内容,例如childNodes、firstChild等。 技巧: Property可以联想一下原型,原型本质上就是对象 ...
attributeproperty区别
薛跳跳的博客
05-25 1765
propertyattribute非常容易混淆,两个单词的文翻译也都非常相近(property属性attribute:特性),但实际上,二者是不同的东西,属于不同的范畴。property是DOM属性,是JavaScript里的对象;attributeHTML标签上的特性,它的值只能够是字符串;...
javascriptattributeproperty区别详解
10-25
JavaScript,`attribute` 和 `property` 是两个与DOM元素相关的概念,它们虽然有所关联,但具有明显的差异。理解这两个概念的区别对于JavaScript开发者来说至关重要,尤其是对于新手来说,混淆这两个概念是常见...
JavaScriptpropertyattribute区别详细介绍
10-24
主要介绍了JavaScriptpropertyattribute区别详细介绍,本文总结了定义、相同这处、不同之处、浏览器兼容性上的差别等内容,并建议优先选择property,需要的朋友可以参考下
详解JSattribute属性
10-19
需要注意的是,attribute属性property属性(元素的标准属性)在JavaScript是不同的。property属性是DOM对象直接提供的标准属性,而attribute属性则是元素在HTML标签定义的属性。通常,当对HTML属性进行读取或...
javascript 对象属性property与元素属性attribute的浏览器支持
12-12
在探讨JavaScript对象属性Property)与元素属性Attribute)及其浏览器支持情况之前,我们需要先理解这两个概念的基本含义以及它们之间的区别。接下来,我们将深入分析这两种属性的特点、应用场景以及不同浏览器...
HTMLattributeproperty区别
BorisHuai前端修炼
07-07 4764
DOM有三种节点类型:元素节点、属性节点、文本节点,HTML里的attribute其实就是指属性节点,举个例子:在Head里,h1是元素节点,id="title"是属性节点,Head是文本节点,在这里可以理解为h1这个元素节点包含一个属性节点和一个文本节点。读写attribute的方法是getAttribute(), setAttribute(), 例如获取id这个属性的值:var tem1 = document.getElementById("title"); var idValue = tem1.get
HTML里,attributeproperty有什么区别
Lee Chen的博客
09-16 731
总之,当你在JavaScriptHTML元素交互时,通常更推荐使用Property,因为它们提供了更丰富、更动态的交互方式。但在某些情况下,特别是当你需要获取HTML源代码的原始值时,使用Attribute可能更有意义。之间的区别是一个常见但容易混淆的概念。它们都与HTML元素有关,但它们在功能、用途和行为上有所不同。属性Property)的行为是不同的。属性Attribute)和。在上面的示例,我们可以看到。
HTMLattribute属性JavaScriptproperty属性的详解以及区别
热门推荐
01-11 2万+
一直没有搞懂attributeproperty区别,弄了个例子,总结了一下。 一、基本概念区别 attribute:是HTML标签上的某个属性,如id、class、value等以及自定义属性,它的值只能是字符串,关于这个属性一共有三个相关的方法,setAttribute、getAttribute、removeAttribute; 注意:在使用setAttribute的时候,该函数一定接收
HTMLATTRIBUTEPROPERTY
2301_79644036的博客
04-26 184
HTML DOM(文档对象模型),每个 HTML 元素都对应一个 JavaScript 对象,这个对象具有与元素相关的属性。这些属性提供了对元素的动态访问和修改能力。属性Attribute)通常以 HTML 标签的形式出现,作为标签的一部分,用于指定元素的初始状态。在 HTML 属性Attribute)和属性Property)是用于描述 HTML 元素的相关特性的术语。- 属性Property)是通过 JavaScript 对象来表示元素的特性,提供了对元素的动态访问和修改能力。
HTML attributeHTML 属性
m0_72006184的博客
07-10 980
HTML attributeHTML 属性)是在 HTML 元素上定义的特性,用于提供关于元素的额外信息或行为。HTML 属性可以应用于各种不同的 HTML 元素,并且每个属性都具有特定于其所属元素的用途和语义含义。:例如,使用 id(唯一标识符)和 data-*(自定义数据属性属性可以为元素提供标识和附加信息。:例如,使用 disabled(禁用)和 readonly(只读)属性可以控制表单元素的可编辑性。:例如,通过 class(类)和 style(样式)属性可以应用 CSS 类和内联样式。
html 设置attribute,详解 HTML attribute 和 DOM property
weixin_33542634的博客
06-25 2440
在大多数的文章attribute 一般被翻译为“特性”,property 被译为“属性”。结论把结论写在最前面,如果你全都懂,后面就不用看了。HTML attributeDOM property值永远是字符串或 null值可以是任意合法 js 类型大小写不敏感大小写敏感不存在时返回 null不存在时返回 undefined对于 href, 返回 html 设置的值对于 href 返回解析后的完...
使用MVC框架要注意的问题(七):HtmlAttributes
weixin_34221773的博客
12-29 151
在MVC的View,我们可以通过HtmlHelper的一些扩展方法插入一些控件,例如通过Html.TextBox插入一个文本框等等,下面是一个简单的范例&lt;%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage" %&gt; ...
是时候拯救我的 HTML 技术了!
程序员小乐
12-14 247
点击上方 "程序员小乐"关注,星标或置顶一起成长每天凌晨00点00分,第一时间与你相约每日英文I'm not even upset, hurt, or ang...
HTMLattribute和DOM的property
扑满大师
06-18 715
虽然attributeproperty都在被翻译成属性,但是他们的含义不同 在angular2的教程里,重点的说明了下这个问题 [title]="myTitle">Save 是button的title属性被绑定了吗?是,但是刨根问底,是dom的title的property被绑定了,而不是html上的attribute 实验如下: 传送门 可以看到,at
attributeJavascript如何使用
04-16
JavaScript ,可以使用点号或方括号来访问对象的属性。例如,如果有一个名为 myObject 的对象,其包含一个名为 myProperty属性,则可以使用以下语法来访问该属性: 使用点号访问属性: ``` myObject.myProperty; ``` 使用方括号访问属性: ``` myObject["myProperty"]; ``` 如果属性名存储在变量,则必须使用方括号访问该属性: ``` var propertyName = "myProperty"; myObject[propertyName]; ``` 可以在对象字面量定义属性和值,如下所示: ``` var myObject = { myProperty: "property value" }; ``` 也可以使用 Object.defineProperty() 方法来定义属性: ``` Object.defineProperty(myObject, "myProperty", { value: "property value" }); ``` 还可以使用 Object.create() 方法来创建一个新对象,并指定该对象的原型和属性,如下所示: ``` var myObject = Object.create(Object.prototype, { myProperty: { value: "property value" } }); ``` 以上是 attributeJavascript 的使用方法,希望对您有所帮助。
写文章

热门文章

  • Maven Dependency设置,详解! 60576
  • yarn报错error An unexpected error occurred: "https://registry.yarnpkg.com...connect ETIMEDOUT... 29979
  • 使用aop获取方法运行之后的返回值 28375
  • js给json对象增加、删除、修改属性 21608
  • npm更换成淘宝镜像源以及cnpm 19126

分类专栏

  • 服务器 3篇
  • node 2篇
  • mongodb 3篇
  • unbuntu 2篇
  • redis
  • nginx 1篇
  • 工作总结git
  • 工具 1篇
  • http 1篇
  • 缓存 1篇
  • Java aop 1篇
  • Java 金钱类型
  • mybatis 映射问题
  • C
  • C语言中的a-- 和a-1 ,逗号表达式 1篇
  • ftl中后台返回结果值的显示 1篇
  • js 单击
  • js 单击获取值,js双击获取值 1篇
  • ganqingsh
  • js获取值的问题 2篇
  • 生活杂感
  • cron表达式 2篇
  • 代码总结 1篇
  • shiro 1篇
  • springMvc 2篇
  • jQuery 1篇
  • Java基础 3篇
  • 配置文件 1篇
  • mybatis spring springBoot druid 1篇
  • 动态代理 1篇
  • Spring SpringIoc
  • mysql 1篇
  • 反射 3篇
  • method invoke() 反射 1篇
  • 日期插件 laydate 1篇
  • spring自定义注解 1篇
  • spring拦截器 1篇
  • Java 2篇
  • panel easyUI 1篇
  • JDBC事物管理 savePoint
  • Spring事物 1篇
  • 工作总结 1篇
  • maven 2篇
  • spring 配置文件 1篇
  • oracle 1篇
  • mybatis 1篇
  • intellijTomcat 2篇
  • springMvc spring框架整合 1篇
  • try catch finally 1篇
  • replace 1篇
  • maven idea 1篇
  • intellijTomcat 断点 1篇
  • replace 正则表达式 1篇
  • ApplicationContext工具类 1篇
  • HashMap 与Hashtable 的区别 1篇
  • token 1篇
  • CSRF攻击原理及防御 1篇
  • ssm定时任务 1篇
  • SSM框架整合 quartz 定时任务调度 1篇
  • TokenProccessor token工具类 1篇
  • mybatis mapper对象 1篇
  • HttpSession HttpServletRequest 对象 1篇
  • basePath 1篇
  • ajax sync 1篇
  • 码云 1篇
  • html基本结构和语法
  • css 9篇
  • 块状元素 1篇
  • html 9篇
  • 作业 1篇
  • iframe 1篇
  • vue 8篇
  • js 29篇
  • react 5篇
  • webpack 10篇
  • antd 3篇
  • git 2篇
  • 插件 8篇
  • async 1篇
  • canvas 1篇
  • mock 1篇
  • redux 6篇
  • 移动端 1篇
  • 小程序 2篇
  • 定时器 1篇

最新评论

  • css button 的四种状态 focus 伪类

    雨声z: 好像样式顺序没放对, 正常顺序为:focus -> :hover -> :active 不然focus时再hover,hover被覆盖无效?

  • 使用flex布局,子元素怎么高度自适应?

    沐柳: 请问最后解决了吗,怎么解决的呢

  • mongodb启动不了:child process failed, exited with error number 48

    m0_69129997: 第二步可以,在第三步还是出现error number 48

  • 使用flex布局,子元素怎么高度自适应?

    雨过天晴616: 是啊,这个空白怎么还在,空白部分可以给他顶掉吗

  • setTimeout异步

    二哈带你看程序: 谢谢博主,学到了

大家在看

  • 批量检测微信小程序封禁状态的 PHP 脚本示例
  • 专业视频编辑软件 MAGIX VEGAS Pro v21 中文授权版
  • 不再错过任何一个区块!用Node.js + WebSocket轻松实现区块链实时监控
  • C++学习笔记(39)
  • 启动应用程序出现SpeechPal.dll找不到问题

最新文章

  • 安装nvm 和node 的那些事
  • mac 快速安装brew
  • position: sticky
2022年7篇
2021年27篇
2020年51篇
2019年68篇
2018年30篇
2017年72篇

目录

目录

分类专栏

目录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43元 前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

玻璃钢生产厂家莆田小区玻璃钢雕塑生产厂家青阳玻璃钢花盆花器临汾玻璃钢仿铜雕塑厂家大足玻璃钢人物雕塑上海常用商场美陈市场价顺祥玻璃钢雕塑南宁玻璃钢花盆厂泸州商场玻璃钢雕塑黑色玻璃钢花盆厂家玻璃钢五角星雕塑滁州景观玻璃钢雕塑生产厂家肇庆玻璃钢园林雕塑团风玻璃钢花盆花器泉州园林玻璃钢雕塑批发优质玻璃钢道具雕塑价格通化小品系列玻璃钢雕塑安装翻新玻璃钢雕塑厂家贵阳特色玻璃钢雕塑哪家便宜香港岛玻璃钢雕塑制作黄骅玻璃钢门头雕塑驻马店水景玻璃钢人物雕塑制作玻璃钢可以做室外雕塑吗萍乡玻璃钢商场美陈福建室内商场美陈供货商浙江玻璃钢雕塑定制价格福建超市商场美陈售价广州玻璃钢小黄人卡通雕塑商场美陈什么意思德化商场美陈制作潍坊玻璃钢人物雕塑制作香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声单亲妈妈陷入热恋 14岁儿子报警汪小菲曝离婚始末遭遇山火的松茸之乡雅江山火三名扑火人员牺牲系谣言何赛飞追着代拍打萧美琴窜访捷克 外交部回应卫健委通报少年有偿捐血浆16次猝死手机成瘾是影响睡眠质量重要因素高校汽车撞人致3死16伤 司机系学生315晚会后胖东来又人满为患了小米汽车超级工厂正式揭幕中国拥有亿元资产的家庭达13.3万户周杰伦一审败诉网易男孩8年未见母亲被告知被遗忘许家印被限制高消费饲养员用铁锨驱打大熊猫被辞退男子被猫抓伤后确诊“猫抓病”特朗普无法缴纳4.54亿美元罚金倪萍分享减重40斤方法联合利华开始重组张家界的山上“长”满了韩国人?张立群任西安交通大学校长杨倩无缘巴黎奥运“重生之我在北大当嫡校长”黑马情侣提车了专访95后高颜值猪保姆考生莫言也上北大硕士复试名单了网友洛杉矶偶遇贾玲专家建议不必谈骨泥色变沉迷短剧的人就像掉进了杀猪盘奥巴马现身唐宁街 黑色着装引猜测七年后宇文玥被薅头发捞上岸事业单位女子向同事水杯投不明物质凯特王妃现身!外出购物视频曝光河南驻马店通报西平中学跳楼事件王树国卸任西安交大校长 师生送别恒大被罚41.75亿到底怎么缴男子被流浪猫绊倒 投喂者赔24万房客欠租失踪 房东直发愁西双版纳热带植物园回应蜉蝣大爆发钱人豪晒法院裁定实锤抄袭外国人感慨凌晨的中国很安全胖东来员工每周单休无小长假白宫:哈马斯三号人物被杀测试车高速逃费 小米:已补缴老人退休金被冒领16年 金额超20万

玻璃钢生产厂家 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化