javascript类型检测这节主要讲了typeof和instanceof操作符。

一、typeof操作符:

1、typeof在检测基本数据类型时十分方便,针对4种基本数据类型string、number、boolean、undefined将返回它们各自对应的类型字符串:

typeof "time"; //string

typeof 22; //number

typeof true; //boolean

typeof ship; //undefined  ship为未定义变量

2、typeof在检测引用类型object类型时用处不大,因为我们通常并不是想知道某个值是对象,而是想知道它们是什么类型的对象,这时我们需要用到instanceof操作符,instanceof操作符在检测基本数据类型时始终会返回false,因为基本类型不是对象。

3、 typeof是一个操作符,不是一个函数,因此它既可以操作一个具体的值也可以操作一个变量或表达式,它操作的值或变量并不一定要加上括号;

4、使用typeof检测函数时,会返回"function",在safari5及之前版本和chrome7及之前版本中使用typeof检测正则表达式时,由于规范原因,这个操作符也返回"function"。ECMA-262规定任何在内部实现了[call]方法的对象都应该在应用typeof操作符时返回"function"。由于上述浏览器的正则表达式也实现了这个方法,因此对正则表达式应用typeof会返回"function",而在IE和Firefox中,对正则表达式应用typeof会返回"object"。

5、typeof 对未初始化的变量和未声明的变量都会返回"undefined",而其实这两种变量是有区别的,见如下代码:

var time;
alert(time); //undefined; //下面的 timestamp是一个未经过声明的变量 alert(timestamp); //产生错误 alert(typeof time); //undefined alert(typeof timestamp); //undefined

二、typeof容易犯的错误:

1、把返回字符串记错,记成首字母大写,而实际上返回字符串的首字母并不是大写。把"number"记成"Number"、"string"记成"String"、"boolean"记成"Boolean"、"undefined"记成"Undefined"等;

2、忽略typeof在IE和Firefox与在chrome7之前版本和safari5之前版本中的差异。

3、将typeof null == "object"错记成typeof null == "";

《javascript高级程序设计》笔记4.1.4:检测类型的更多相关文章

  1. JavaScript高级程序设计笔记之面向对象

    说起面向对象,大部分程序员首先会想到 类 .通过类可以创建许多具有共同属性以及方法的实例或者说对象.但是JavaScript并没有类的概念,而且在JavaScript中几乎一切皆对象,问题来了,Jav ...

  2. JavaScript高级程序设计笔记(一)

    ---恢复内容开始--- 前三章为基础知识,为了方便以后查看,所以比较啰嗦.这里对函数的基本操作没有记录. 1.JavaScript的实现 虽然 JavaScript 和 ECMAScript 通常都 ...

  3. javascript高级程序设计--笔记01

    概述 JavaScript的实现包含三个部分: 1  核心(ECMAScript)   提供核心语言功能 2  文档对象模型(DOM)  一套提供了访问以及操作网页内容的API 3  浏览器对象模型( ...

  4. javascript事件小结(事件处理程序方式)--javascript高级程序设计笔记

    1.事件流:描述的是从页面中接收事件的顺序. 2.事件冒泡:IE的事件流叫做事件冒泡,即事件开始从具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到不具体的节点(文档). 3.事件捕获 ...

  5. Javascript高级程序设计笔记 <第五章> 引用类型

    一.object类型 创建object实例的方式有两种: //第一种使用new操作符跟构造函数 var person= new Object(); person.name="小王" ...

  6. Javascript高级程序设计笔记(很重要尤其是对象的设计模式与继承)

    var obj = {'a':'a'}; var fun = function (){} console.log(typeof obj);//object console.log(typeof fun ...

  7. JavaScript高级程序设计笔记 事件冒泡和事件捕获

    1.事件冒泡 要理解事件冒泡,就得先知道事件流.事件流描述的是从页面接收事件的顺序,比如如下的代码: <body> <div> click me! </div> & ...

  8. <javascript高级程序设计>笔记

    1.要讲一个值转换成其对应的Boolean类型 ,可以调用转型函数Boolean(). var message=“hello world!”; var messageAsBoolean=Boolean ...

  9. javaScript高级程序设计笔记 2

    Undefinde Null Boolean Number String    基本类型 Object    引用类型 只有引用类型才能动态的添加属性 赋值基本类型和引用类型也不相同,复制的基本类型的 ...

  10. javaScript高级程序设计笔记 1

    核心  ECMAScript 文档对象模型  DOM 浏览器对象模型 BOM 延迟脚本  defer typeof操作符      判断字符类型  返回   undefined  boolean  s ...

随机推荐

  1. Oracle 10g体系结构及安全管理

    (1)               Oracle数据库服务器:数据库,实例 (2)               数据库:(1)物理存储—数据文件,控制文件,日志文件,(2)逻辑存储—表空间,段,区间, ...

  2. Js与Jq 获取浏览器和对象值的方法

    JS and Jquery 都能获取页面元素的宽度,高度和相对位移等数值,那他们之间能相互转换或替代吗,写法又有哪些差异呢?本文将详细为你介绍. 1.Js获取浏览器高度和宽度document.docu ...

  3. LAMP 环境搭建之源码包编译安装

    mysql用的二进制包安装. Apache php 用的源码包 mysql版本5.5.46    Apache版本2.4.7  PHP版本:5.5 mysql安装部分参考了阿铭linux的内容. 这是 ...

  4. Netbeans使用Xdebug调试的配置

    在phpinfo()信息里找到php.ini的位置并打开php.ini在文档最后添加如下代码: 注释原来xdebug配置 xdebug.remote_enable=onxdebug.remote_ha ...

  5. java.lang.OutOfMemoryError: unable to create new native thread(转)

    解决 - java.lang.OutOfMemoryError: unable to create new native thread 工作中碰到过这个问题好几次了,觉得有必要总结一下,所以有了这篇文 ...

  6. logstash date插件介绍

    时间处理(Date) 之前章节已经提过, filters/date 插件可以用来转换你的日志记录中的时间字符串,变成 LogStash::Timestamp 对象,然后转存到 @timestamp 字 ...

  7. libeXosip2(1-3) -- How-To send or update registrations.

    How-To send or update registrations. The eXtented eXosip stack Initiate a registration To start a re ...

  8. CSS3 新特性 开放字体格式WOFF

    疑问 上面这是虾米玩意?    \e806 是在自定义字体表中的字体位置.    好嘛 现在问题来了 WOFF里面是什么东西呢? 怎么才能看到? 用这个:FontCreatorPortable     ...

  9. hdu1067-Gap(bfs+哈希)

    Let's play a card game called Gap. You have 28 cards labeled with two-digit numbers. The first digit ...

  10. hdu 3711 Binary Number(暴力 模拟)

    Problem Description For non-negative integers x and y, f(x, y) , )=,f(, )=, f(, )=. Now given sets o ...