位置: 编程技术 - 正文

JS中attr和prop属性的区别以及优先选择示例介绍(jquery中attr和prop)

编辑:rootadmin

推荐整理分享JS中attr和prop属性的区别以及优先选择示例介绍(jquery中attr和prop),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js的attribute,js中attr的用法,js prop attr,js里的attr,js中attribute,js中attribute和property,js中attribute,js中attribute和property,内容如对您有帮助,希望把文章链接给更多的朋友!

相比attr,prop是1.6.1才新出来的,两者从中文意思理解,都是获取/设置属性的方法(attributes和properties)。只是,window或document中使用.attr()方法在jQuery1.6之前不能正常运行,因为window和document中不能有attributes。prop应运而生了。

既然我们想知道他们两的区别,最好就看看他们的源代码,不要被代码长度所吓到,我们只看关键的几句:

prop方法代码(jQuery版本1.8.3)

attr方法里面,最关键的两行代码,elem.setAttribute( name, value + “” )和ret = elem.getAttribute( name ),很明显的看出来,使用的DOM的API setAttribute和getAttribute方法操作的属性元素节点。而prop方法里面,最关键的两行代码,return ( elem[ name ] = value )和return elem[ name ],你可以理解成这样document.getElementById(el)[name] = value,这是转化成JS对象的一个属性。

既然明白了原理是这样,我们来看看一个例子:

el.attr(“style”)输出undefined,因为attr是获取的这个对象属性节点的值,很显然此时没有这个属性节点,自然输出undefinedel.prop(“style”)输出CSSStyleDeclaration对象,对于一个DOM对象,是具有原生的style对象属性的,所以输出了style对象至于document.getElementById(“test”).style和上面那条一样

接着看:

首先用attr方法给这个对象添加abc节点属性,值为,可以看到html的结构也变了

el.attr(“abc”)输出结果为,再正常不过了el.prop(“abc”)输出undefined,因为abc是在这个的属性节点中,所以通过prop是取不到的

JS中attr和prop属性的区别以及优先选择示例介绍(jquery中attr和prop)

我们再用prop方法给这个对象设置了abc属性,值为,可以看到html的结构是没有变化的。输出的结果就不解释了。

上面已经把原理讲清楚了,什么时候用什么就可以自己把握了。

提一下,在遇到要获取或设置checked,selected,readonly和disabled等属性时,用prop方法显然更好,比如像下面这样:

显然,布尔值比字符串值让接下来的处理更合理。

PS一下,如果你有JS性能洁癖的话,显然prop的性能更高,因为attr需要访问DOM属性节点,访问DOM是最耗时的。这种情况适用于多选项全选和反选的情况。

大家都知道有的浏览器只要写disabled,checked就可以了,而有的要写成disabled = "disabled",checked="checked",比如用attr("checked")获取checkbox的checked属性时选中的时候可以取到值,值为"checked"但没选中获取值就是undefined。

jq提供新的方法“prop”来获取这些属性,就是来解决这个问题的,以前我们使用attr获取checked属性时返回"checked"和"",现在使用prop方法获取属性则统一返回true和false。

那么,什么时候使用attr(),什么时候使用prop()?1.添加属性名称该属性就会生效应该使用prop();2.是有true,false两个属性使用prop();3.其他则使用attr();项目中jquery升级的时候大家要注意这点!

以下是官方建议attr(),prop()的使用:

以下是官方建议attr(),prop()的使用:

javascript数组操作方法小结和3个属性详细介绍 最近一直在用js,好好研究了下js数组的操作,在这里总结一下。1、数组的创建vararrayObj=newArray();//创建一个数组vararrayObj=newArray([size]);//创建一个数组并

中文输入法不触发onkeyup事件的解决办法 这两天做一个需要实时监控文本框输入的功能,碰到了中文输入法无法触发onkeyup事件的恶心问题。具体表现是这样的:当监听一个input的keyup的事件的

js中一维数组和二位数组中的几个问题示例说明 js中的数组,可以存放各种数据类型(数值,字串)js中的数组没有越界,当输出的数组下标越界了,会显示undefined。js中的数组是默认动态增长的遍历

标签: jquery中attr和prop

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

上一篇:javascript时间函数大全(js时间范围)

下一篇:javascript数组操作方法小结和3个属性详细介绍(javascript数组的方法)

  • 开具增值税发票未报送是什么意思?
  • 汇算清缴哪些需要调增调减
  • 个人报销电话费怎么做分录
  • 赔偿支出需要纳税调整吗
  • 公司亏损股东退股还要贴钱
  • 物业代收费:有关法律
  • 应付职工薪酬如何具体到个人
  • 向金融企业借款利息支出可以税前扣除吗
  • 公司注销未登记债权,债务人如何抗辩
  • 怎么确认收到的钱是哪个项目的
  • 关联企业税收
  • 企业盈利后又亏损怎么算
  • 跨地区经营建筑企业预缴增值税可以先开票后预缴吗
  • 技术开发加计扣除
  • 招待客人买的烟计入业务招待费吗
  • 一般纳税人资格证明在哪里开具
  • 股权转让会计处理
  • 期末留抵税额退税额
  • macOS Catalina10.15.2值得升级吗 macOS Catalina10.15.2更新了什么
  • linux怎么查找
  • 代缴社保怎么做账
  • php的认识
  • php string函数
  • 我的电脑图标没了怎么恢复
  • 公允价值变动损益会计处理
  • 工作完工结算是什么意思
  • 房地产企业增值税怎么计算
  • zmweb.exe是什么进程
  • adblock规则编写
  • wordpress经典编辑器用法
  • PHP:zip_entry_read()的用法_Zip函数
  • 薄雾笼罩着整个森林
  • codevein配置要求
  • 微笑的树懒哥斯达黎加
  • 劳务费还没发可以先计提吗
  • vue.js如何安装
  • 嵌入式开关安装效果图
  • 前端实战开发
  • es6 promise finally
  • Pytorch深度学习实战3-7:详解数据加载DataLoader与模型处理
  • php获取文件内容的方法
  • sed指令可以打印文件的奇数或偶数行
  • GCC strict aliasing – 嫉妒就是承认自己不如别人
  • 二手车征税税率减按多少税
  • 什么是电子税务局app
  • 加班补贴费
  • 公司开具手工发票怎么开
  • 未按期兑现的合同缴纳印花税吗?
  • 现金存入银行如何做账
  • 知道实发工资怎么算应发工资计算器
  • 一般纳税人购销合同印花税减免政策
  • 权益法下公允价值变动计入其他综合收益
  • 增值税纳税申报类型有哪些
  • 年报中的资产总额怎么计算
  • 促销费会计分录怎么写
  • 长期闲置机器设备评估方法
  • 金税盘技术维护费
  • 进项税和销项税月末怎么结转
  • 预收账款转收入的条件
  • 从事小额零星经营业务的个人,其支出
  • 转账支票的密码需要填写吗
  • 账户记录试算不平衡说明记账肯定有差错对吗
  • windows vista(service pack1)
  • bootcamp您的磁盘未能分区
  • centos6.10安装教程详解
  • mac系统怎么创建用户
  • linux 多线程 写文件
  • win7系统怎么调出运行窗口
  • 举例讲解水生花卉栽培管理
  • js限制数组长度
  • find 批处理
  • jquery升级
  • 在Debian(Raspberry Pi)树莓派上安装NodeJS的教程详解
  • 用python写爬虫
  • javascript获取数据类型
  • 基于JavaScript的网页代码
  • 土地增值税有哪些税收优惠
  • 吉林省耕地面积有多少万亩
  • 网上办税服务厅
  • 中国采购网地胶
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设