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 相关文章推荐
文本有关的样式和jQuery求对象的高宽问题分别说明
Aug 30 Javascript
jQueryMobile之Helloworld与页面切换的方法
Feb 04 Javascript
JS封装的三级联动菜单(使用时只需要一行js代码)
Oct 24 Javascript
常用原生js自定义函数总结
Nov 20 Javascript
JavaScript BASE64算法实现(完美解决中文乱码)
Jan 10 Javascript
分享bootstrap学习笔记心得(组件及其属性)
Jan 11 Javascript
JavaScript字符串对象
Jan 14 Javascript
vue-router实现webApp切换页面动画效果代码
May 25 Javascript
React-Native实现ListView组件之上拉刷新实例(iOS和Android通用)
Jul 11 Javascript
小程序自定义组件实现城市选择功能
Jul 18 Javascript
Vue实现底部侧边工具栏的实例代码
Sep 03 Javascript
vue-cli3 项目优化之通过 node 自动生成组件模板 generate View、Component
Apr 30 Javascript
$.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
mantis安装、配置和使用中的问题小结
2014/07/14 PHP
php中FTP函数ftp_connect、ftp_login与ftp_chmod用法
2014/11/18 PHP
PHP实现冒泡排序的简单实例
2016/05/26 PHP
PHP5.4起内置web服务器使用方法
2016/08/09 PHP
PHPWind9.0手动屏蔽验证码解决后台关闭验证码但是依然显示的问题
2016/08/12 PHP
PHP与JavaScript针对Cookie的读写、交互操作方法详解
2017/08/07 PHP
显示js对象所有属性和方法的函数
2009/10/16 Javascript
JQuery 技巧和窍门整理(8个)
2010/04/22 Javascript
js优化针对IE6.0起作用(详细整理)
2012/12/25 Javascript
jquery对dom的操作常用方法整理
2013/06/25 Javascript
基于jquery实现的省市区级联无ajax
2013/09/24 Javascript
jquery验证邮箱格式并显示提交按钮
2015/11/07 Javascript
Vue.js中数据绑定的语法教程
2017/06/02 Javascript
Vue.js做select下拉列表的实例(ul-li标签仿select标签)
2018/03/02 Javascript
vue项目打包上传github并制作预览链接(pages)
2019/04/19 Javascript
JQuery样式操作、click事件以及索引值-选项卡应用示例
2019/05/14 jQuery
详解基于Vue的支持数据双向绑定的select组件
2019/09/02 Javascript
基于js实现的图片拖拽排序源码实例
2020/11/04 Javascript
20招让你的Python飞起来!
2016/09/27 Python
python+opencv实现动态物体追踪
2018/01/09 Python
python+matplotlib绘制饼图散点图实例代码
2018/01/20 Python
python3爬取数据至mysql的方法
2018/06/26 Python
Python3+Appium安装使用教程
2019/07/05 Python
Python 将json序列化后的字符串转换成字典(推荐)
2020/01/06 Python
python实现堆排序的实例讲解
2020/02/21 Python
Python通过yagmail实现发送邮件代码解析
2020/10/27 Python
python实现学生通讯录管理系统
2021/02/25 Python
澳大利亚潮流尖端的快时尚品牌:Cotton On
2016/09/26 全球购物
世界领先的以旅馆为主的在线预订平台:Hostelworld
2016/10/09 全球购物
英国第一的市场和亚马逊替代品:OnBuy
2019/03/16 全球购物
人力资源求职信
2014/05/25 职场文书
团队执行力培训心得体会
2015/08/15 职场文书
2016年国培研修日志
2015/11/13 职场文书
2016年教代会开幕词
2016/03/04 职场文书
小学生必读成语故事大全:送给暑假的你们
2019/07/09 职场文书
创业计划书之孕婴生活馆
2019/11/11 职场文书