prop和attr的区别

一、区别

  • prop 是从属性对象上获取值,属性对象上有多少属性,就能获取多少值,不需要在页面上显示定义。
  • attr 是从页面搜索上获取元素值,所以页面必须明确定义元素才能获取值,相对时间来说较慢。

二、使用

在HTML元素本身就自带的固有属性,在处理方法时,就选择prop。
在HTML元素定义一些我们自定义的DOM属性时 ,在处理方法时,就用attr。

三、总结:

在高版本jquery引入使用的方法,可以用 a、input标签来测试,

  1. 本身就带有的属性,也是W3C标准里就包含有这几个属性,或者说在IDE里能够智能提示出的属性,这些就叫做固有属性。处理这些属性时,建议使用prop方法。
  2. 属性是我们自己自定义上去的,元素本身是没有这个属性的。这种就是自定义的DOM属性。处理这些属性时,建议使用attr方法。使用prop方法取值和设置属性值时,都会返回undefined值。
null和undefined的区别

null:
是空对象引用,引用指向为空;
是一个表示“无”的对象,转为数值时是0;
用来表示尚未存在的对象,常用来表示函数企图返回一个不存在的对象;
typeof null:“object”

undefined:
是只定义了引用;
是一个表示无的原始值,转为数值时是NaN;
当声明变量还未被初始时,变量的默认值为undefined,表示“缺少值”;
typeof undefined : “undefined”

注意均可以用“null”或者“undefined”来清空属性

typeof和instanceof的区别

typeof

一般用来判断基本数据类型,是一个操作符,而不是函数,圆括号可以可无;
常用来判断一个变量是否为空,或者判断参数是什么类型的实例,返回值为说明类型的字符串;
返回值:‘number’,‘boolean’,‘string’,‘object’,‘function’,‘undefined’
若参数为引用类型,始终返回‘object’,对于array,null始终返回‘object’,无法正确判断,存在局限性。

instanceof

判断一个变量是否是数组或者对象,就是检测某个对象是不是另一个对象的实例;
简单基本数据类型不能使用instanceof判断,因为内部机制是通过原型链来判断的;
a instanceof b:判断a是否为b的实例;对于所有的引用类型,均为Object的实例。

总结检测数据类型的方法:

typeof :检测基本数据类型通常用到
instanceof:判断左侧的数据是不是右侧的实例化对象
Array.isArray:只能用来判断对象是否为数组
isNaN: 检测数值或者变量名(不要用NaN 验证是不是NaN,小数也是样)
Object.prototype.toString.call(): 对所有的基本数据类型都能进行判断。让某类型数据通过call借代,调用Object根类自己的toString,这样就能还原toString自己的作用

javascript基础常识问答(二)相关推荐

  1. Javascript基础回顾 之(二) 作用域

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...

  2. JavaScript基础知识(二)

    DOM学习 * 功能:控制html文档的内容 * 获取页面标签(元素)对象:Element* document.getElementById("id值"):通过元素的id获取元素对 ...

  3. Javascript基础回顾 之(一) 类型

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...

  4. 一.JavaScript基础

    目录 一.什么是javaScript基础 (一)特点: (二)javaSrcipt组成部分: (三)javaSrcipt的基本结构: (三)javaSrcipt的核心语法: (四)javaSrcipt ...

  5. Javascript基础知识之四(常用数组方法)

    一.MDN链接 Array - JavaScript | MDNJavaScript的 Array 对象是用于构造数组的全局对象,数组是类似于列表的高阶对象.https://developer.moz ...

  6. JavaScript基础语法(一)

    目录 前言 js变量 数据类型 数据类型转换 传送门 --> JavaScript基础语法(二).JavaScript之数组与函数(三).JavaScript之对象(四).JavaScript阶 ...

  7. Javascript基础(二)

    Javascript基础(二) 事件: 条件语句 类型转换 正则表达式regexp 错误抛出 void 事件: 是发生在HTML元素上的行为,可以是浏览器行为,可以是用户行为 a) html 元素添加 ...

  8. JavaScript 基础知识 - DOM篇(二)

    7. 节点操作 7.1 节点的属性 节点分类: 标签节点 文本节点 属性节点 注释节点 节点常用的属性: nodeType:节点的类型 nodeName:节点名称 nodeValue:节点值 常见的节 ...

  9. JavaScript 基础知识 - 入门篇(二)

    11. 函数 11.1 函数的基础知识 为什么会有函数? 在写代码的时候,有一些常用的代码需要书写很多次,如果直接复制粘贴的话,会造成大量的代码冗余: 函数可以封装一段重复的javascript代码, ...

  10. ArcGIS API for JavaScript之基础篇(二)

    ArcGIS API for JavaScript之基础篇(二) 上一篇文章介绍了Map MapView SceneView的基本知识以及简单的demo.最近几天学习了WebMap WebScene ...

最新文章

  1. Java面向对象知识点精华
  2. 运行 YunYang1994/tensorflow-yolov3 所遇到的一些问题记录
  3. pytorch 指定卡1_在pytorch中指定显卡
  4. 价值连城 ImageNet图像分类大神 Andrej Karpathy的采访 给AI 深度学习从业者的建议
  5. 圣诞节桌面特效圣诞树程序(含运行效果和百度网盘直接运行程序分享)
  6. 开机时HP Hotkey UWP Service占用内存过高
  7. [打新技巧]打新股产品跷跷板定律
  8. “瓮中捉鳖”——涨停板一般出现在什么时候?
  9. 电商系统:优惠券实体设计、数据库表设计、满减券、运费券
  10. 微信小程序引用php函数,php微信小程序支付讲解(JSAPI)
  11. 计算机组成原理实验箱D7,计算机组成原理实验(实验箱).doc
  12. VINS-mono 学习之 三角化
  13. moxa串口服务器网页访问失败,moxa串口服务器连接设置
  14. <RTL设计的艺术> DDR带宽计算公式
  15. Windows的使用技巧(一)
  16. oracle写SQL快捷键,Oracle数据库PL/SQL快捷键设置详解
  17. GO语言-gox交叉编译
  18. 虹膜识别论文4:DeepIris: Learning pairwise filter bank for heterogeneous iris verification 2015
  19. 微信分销系统,你使用了吗?
  20. c++数组求和函数 accumulate()

热门文章

  1. Java .class文件是什么?
  2. 离散数学——成真赋值与成假赋值
  3. android studio超级玛丽源码,VR版NES模拟器来了,超级玛丽、魂斗罗都支持
  4. 线性代数Python计算:矩阵对角化
  5. BusinessSkinForm VCL
  6. linux , Shell 文件合并的命令
  7. Tableau 中国最美八条骑行线路(一)线路地图
  8. Incorrect string value: '\xF0\x9F\x91\x93\xF0\x9F...' for column 'xxx' at row 1
  9. 推荐算法中CTR和CVR的ESMM模型pytorch实现
  10. Android权限设置 for Unity