jQuery中attr()和prop()在修改checked属性时的区别


Posted in Javascript onJuly 18, 2014

在做复选框全选按钮的时候,出现了一个问题,使用语句$.attr('checked',true),将复选框的属性改为被选中,在chrome浏览器中第一次点击有效后面就不行了,IE8倒是没有问题。

百度了很久找到原因是HTML的属性分为attribute和property,暂且将后者称为特性。

checked属性即分为attribute->checked,和property->true,false。

对于一个checkbox,若未定义checked="checked",alert($.attr("checked")) 的结果是undefined。若已定义则结果是checked。attribute并不随着checkbox的状态变化而改变。

使用prop($.attr("checked"))的话输出则分别为false和true。property则随其变化而变化。

所以在修改checked属性时要使用prop()。prop()在jQuery1.6版本后新增。

网上关于其他类似属性的图表:
jQuery中attr()和prop()在修改checked属性时的区别

另外关于在IE9之前版本中,如果property没有在DOM元素被移除之前删除,使用.prop()方法设置DOM元素property(简单类型除外:number、string、boolean)的值会导致内存泄露。为了安全的设置DOM对象的值,避免内存泄露,可以使用.data()方法。 目前尚未遇到,先记在这里。

Javascript 相关文章推荐
javascript 贪吃蛇实现代码
Nov 22 Javascript
javascript动态添加表格数据行(ASP后台数据库保存例子)
May 08 Javascript
jquery实现多行文字图片滚动效果示例代码
Oct 10 Javascript
node.js中的fs.lchmod方法使用说明
Dec 16 Javascript
jQuery实现移动 和 渐变特效的点击事件
Feb 26 Javascript
javascript设计模式之中介者模式学习笔记
Feb 15 Javascript
jQuery实现的动态文字变化输出效果示例【附演示与demo源码下载】
Mar 24 jQuery
angular select 默认值设置方法
Jun 23 Javascript
JavaScript实现多文件下载方法解析
Aug 07 Javascript
H5+css3+js搭建带验证码的登录页面
Oct 11 Javascript
antd form表单数据回显操作
Nov 02 Javascript
Vue 实例中使用$refs的注意事项
Jan 29 Vue.js
$.each遍历对象、数组的属性值并进行处理
Jul 18 #Javascript
js 模式窗口(模式对话框和非模式对话框)的使用介绍
Jul 17 #Javascript
一个小例子解释如何来阻止Jquery事件冒泡
Jul 17 #Javascript
iframe调用父页面函数示例详解
Jul 17 #Javascript
js中一维数组和二位数组中的几个问题示例说明
Jul 17 #Javascript
js中函数调用的两种常用方法使用介绍
Jul 17 #Javascript
jQuery中关于ScrollableGridPlugin.js(固定表头)插件的使用逐步解析
Jul 17 #Javascript
You might like
php 操作数组(合并,拆分,追加,查找,删除等)
2012/07/20 PHP
php抽象方法和抽象类实例分析
2016/12/07 PHP
yii2.0整合阿里云oss上传单个文件的示例
2017/09/19 PHP
php操作redis数据库常见方法实例总结
2020/02/20 PHP
基于JQuery 的消息提示框效果代码
2011/07/31 Javascript
js字符串日期yyyy-MM-dd转化为date示例代码
2014/03/06 Javascript
原生javascript实现匀速运动动画效果
2016/02/26 Javascript
简单讲解AngularJS的Routing路由的定义与使用
2016/03/05 Javascript
微信小程序购物商城系统开发系列-工具篇的介绍
2016/11/21 Javascript
JS实现的系统调色板完整实例
2016/12/21 Javascript
微信小程序实现顶部普通选项卡效果(非swiper)
2020/06/19 Javascript
js封装成插件的步骤方法
2017/09/11 Javascript
为vue-router懒加载时下载js的过程中添加loading提示避免无响应问题
2018/04/03 Javascript
详解Nodejs内存治理
2018/05/13 NodeJs
Vue表单及表单绑定方法
2018/09/04 Javascript
Vue中使用 setTimeout() setInterval()函数的问题
2018/09/13 Javascript
vue实现类似淘宝商品评价页面星级评价及上传多张图片功能
2018/10/29 Javascript
基于javascript的无缝滚动动画1
2020/08/07 Javascript
Python模拟登录的多种方法(四种)
2018/06/01 Python
Python socket实现的简单通信功能示例
2018/08/21 Python
python2与python3中关于对NaN类型数据的判断和转换方法
2018/10/30 Python
Python http接口自动化测试框架实现方法示例
2018/12/06 Python
解决python打不开文件(文件不存在)的问题
2019/02/18 Python
Python使用gluon/mxnet模块实现的mnist手写数字识别功能完整示例
2019/12/18 Python
python3+openCV 获取图片中文本区域的最小外接矩形实例
2020/06/02 Python
1688平价精选商城:阿里集团旗下,工厂出厂价格直销
2017/04/24 全球购物
设计师珠宝:Ylang 23
2018/05/11 全球购物
考博自荐信
2013/10/25 职场文书
缓刑人员的思想汇报
2014/01/11 职场文书
教师节商场活动方案
2014/02/13 职场文书
新农村建设典型材料
2014/05/31 职场文书
英语教育专业毕业生求职信
2014/08/28 职场文书
2014年党支部书记工作总结
2014/12/04 职场文书
2015年全民国防教育日活动总结
2015/03/23 职场文书
简单实现一个手持弹幕功能+文字抖动特效
2021/03/31 HTML / CSS
Python PIL按比例裁剪图片
2022/05/11 Python