位置: 编程技术 - 正文

JavaScript中property和attribute的区别详细介绍

编辑:rootadmin

推荐整理分享JavaScript中property和attribute的区别详细介绍,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

1. 定义

Property:属性,所有的HTML元素都由HTMLElement类型表示,HTMLElement类型直接继承自Element并添加了一些属性,添加的这些属性分别对应于每个HTML元素都有下面的这5个标准特性: id,title,lang,dir,className。DOM节点是一个对象,因此,他可以和其他的JavaScript对象一样添加自定义的属性以及方法。property的值可以是任何的数据类型,对大小写敏感,自定义的property不会出现在html代码中,只存在js中。

Attribute:特性,区别于property,attribute只能是字符串,大小写不敏感,出现在innerHTML中,通过类数组attributes可以罗列所有的attribute。

2. 相同之处

标准的 DOM properties 与 attributes 是同步的。公认的(非自定义的)特性会被以属性的形式添加到DOM对象中。如,id,align,style等,这时候操作property或者使用操作特性的DOM方法如getAttribute()都可以操作属性。不过传递给getAttribute()的特性名与实际的特性名相同。因此对于class的特性值获取的时候要传入“class”。

3. 不同之处

1).对于有些标准的特性的操作,getAttribute与点号(.)获取的值存在差异性。如href,src,value,style,onclick等事件处理程序。2).href:getAttribute获取的是href的实际值,而点号获取的是完整的url,存在浏览器差异。

src的值的获取类似href,不过IE也会返回full URL;value值同样存在一些 ‘one-way'(单向)同步的内置属性。例如,input.value 从 attribute 中同步(即 property 从 attribute 中获得同步)

JavaScript中property和attribute的区别详细介绍

但是 attribute 不能从 property 中获得同步:

getAttribute获取的是初始值,而点号获取的是初始值或者.value修改后的值,例如当访问者输入了某些字符后,'value' attribute 在 property 更新后维持了原始值。原始值可以用来检验 input 是否变化,或者重置它。

对于style和onclick等事件处理程序,getAttribute方法访问时会返回字符串,而点号返回的是相应的对象和事件处理函数。

对于input中的checked属性

getAttribute获取的是你是实际设置的值。而点号返回的是布尔值。

浏览器兼容性上的差别

1.在IE<9的浏览器中,可以用点号和getAttribute在相互之间访问自定义属性。2.IE<8(包括IE8种的IE7兼容模式),property和attribute相同。因为attribute对大小写不敏感,在这种情况下,用getAttribute访问特性的时候,浏览器会选择第一次出现的值。

优先选择property

在实际应用中,%的 DOM 操作都是使用 properties。只有两种情形需要使用attributes

1.自定义 HTML attributes,因为它并不同步到DOM property。2.访问内置的 HTML attributes,这些 attribute 不能从 property 同步过来。例如 INPUT标签的value值。

浅谈JavaScript数据类型 1.数据类型是什么?我们接触的绝大多数程序语言来说,把数据都进行了分类,包括数字、字符、逻辑真假:int,long,string,boolean....等等;我们都知道

深入理解JavaScript系列():设计模式之享元模式详解 介绍享元模式(Flyweight),运行共享技术有效地支持大量细粒度的对象,避免大量拥有相同内容的小类的开销(如耗费内存),使大家共享一个类(元类)。

深入理解JavaScript系列():设计模式之中介者模式详解 介绍中介者模式(Mediator),用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改

标签: JavaScript中property和attribute的区别详细介绍

本文链接地址:https://www.jiuchutong.com/biancheng/382856.html 转载请保留说明!

上一篇:ECMAScript 5严格模式(Strict Mode)介绍(严格模式的作用)

下一篇:浅谈JavaScript数据类型(javascript中数组的方法)

  • 3901100090的暂定税率
  • 材料入库的会计分录材料采购损失
  • 用友t3软件的系统内没有利润表模块
  • 8000块电脑大概能跑多少分
  • 邀请客户参加公司会议
  • 个税里任职受雇从业类型
  • 报关单找不到了怎么办
  • 行政事业单位凭证培训课件
  • 无形资产增资需要缴纳个税吗
  • 递延收益金额怎么算
  • 拆迁置换安置房
  • 处理固定资产一个月卖一点
  • 商品入库时的会计分录
  • 社保和公积金缴费基数怎么算
  • 增值税普通发票税率
  • 劳务公司注销了,未出的款怎么走账
  • 旧房转让土地增值税计算
  • 小规模季度超过30万,普票咋交税
  • 铝合金失效分析案例
  • 最新《资源税纳税标准
  • 会计成本核算的三种基本方法
  • 一张发票上可以开几行
  • 物流服务费税率是多少
  • 企业接收股东划入资产作为收入处理有所得税差异吗
  • 老板私车转让给老板
  • win10待机久了自动关机
  • php框架怎么写
  • 跨年冲减无发票怎么入账
  • php中undefined index
  • 税前扣除项目什么意思
  • 暂估价是单价还是总价
  • web前端开发 vue
  • 餐饮小微企业优惠政策2021
  • 预缴税款计入什么科目
  • 个人出租房可开发票吗
  • 资产负债表中应交税费为负数是什么意思
  • 哪些收入需缴纳增值税
  • 年均复合增长率该怎么算?
  • 业务活动成本和管理费用能不能写在一起
  • 金税四期上线企业还活吗
  • 什么是现金什么是现金流
  • 税务师有用么,相当于中级还是高级
  • 房地产采取按揭销售的,其销售的入账时间为
  • 小规模纳税人进项票可以抵扣吗
  • 工人发生工伤的责任划分
  • 企业筹建期间银行开户要求
  • 补发工资如何计税计算
  • 一般纳税人增值税减免政策2023
  • 商业承兑到期对方不付款会计分录
  • 车辆购置税在哪个app交
  • 分期付款进项税额怎么算
  • 冲减和冲销的会计分录
  • 五险一金的正确说法
  • 计提坏账准备需要哪些资料
  • 补缴企业所得税
  • 流动资产周转天数下降说明什么
  • 粘贴板有问题不能粘贴怎么处理
  • win101909激活
  • ubuntu软件安装
  • 电脑ems是什么意思啊
  • win8宽带错误651最简单解决方法
  • win7关闭445端口 注册表
  • 超大安卓游戏
  • div li
  • easyui multiple
  • js传参数有长度限制
  • jquery添加图片
  • 用vue写登录页面
  • 代码行数不够了,怎么弄多行
  • 请问在javascript程序中
  • android studio报错
  • 辽宁省视同缴费标准?
  • 晋城兰花集团招聘
  • 青岛税务局局长是什么级别?
  • 河南农村社保查询个人账户查询系统
  • 资源税的征税范围一般包括
  • 婚育证明可以开假的吗
  • 无房怎么办
  • 2o21年公租房
  • 季度申报忘了报怎么办
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设