博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript数据类型
阅读量:7069 次
发布时间:2019-06-28

本文共 2435 字,大约阅读时间需要 8 分钟。

1. typeof 运算符

返回一个用来表示表达式的数据类型的字符串。

typeof expression ;

expression 参数是需要查找类型信息的任意表达式。

说明

typeof 是一个一元运算符,放在一个运算数之前。

typeof 运算符把类型信息当作字符串返回。typeof 返回值有六种可能: “number” ,“string”, “boolean”, “object” ,“function”, 和 “undefined.”

(而 ECMAScript 有 5 种原始类型(primitive type),即 Undefined、Null、Boolean、Number 和 String。)

4. instanceof运算符

是一个二元运算符。返回一个 Boolean 值,指出对象是否是特定类的一个实例。

expression  instanceof class

参数

 expression  必选项。任意对象表达式。

 class  必选项。任意已定义的对象类。

说明

如果 object 是 class 的一个实例,则 instanceof 运算符返回 true 。如果 object不是指定类的一个实例,或者 object 是 null ,则返回 false 。

用于判断一个变量是否某个对象的实例,

如:

var a=new Array();

alert(a instanceof Array);会返回true,

同时alert(a instanceof Object)也会返回true;

这是因为Array是object的子类。

再如:

function test(){};

var a=new test();

alert(a instanceof test)会返回true。

而对于使用typeof的话:

function Person(){}

document.write ("<br>typeof(Person):"+typeof(Person));    //function
var person = new Person();
document.write ("<br>typeof(person):"+typeof(person));    //object

2. 

alert(null == undefined);  //输出 "true"

尽管这两个值相等,但它们的含义不同:

undefined 是声明了变量但未对其初始化时赋予该变量的值 或 未声明过的变量(只能用于typeof,但作为赋值目标时编译器会自动将其声明为全局变量)。

null 则用于表示尚未存在的对象(即对象为空,或对象找不到)。如果函数或方法要返回的是对象,那么找不到该对象时,返回的通常是 null。

3.

我们可以使用 typeof 来获取一个变量是否存在,如 if(typeof a!="undefined"){alert("ok")},而不要去使用 if(a) 因为如果 a 不存在(未声明)则会出错。

对于 Array,Null 等特殊对象使用 typeof 一律返回 object,这正是 typeof 的局限性。如果我们希望获取一个对象是否是数组,或判断某个变量是否是某个对象的实例则要选择使用instanceof

 

判断一个变量是数组Array类型的方法 

 

25个你需要知道的JavaScript面试题:

以下主要是摘要,具体详情还请打开链接查看

立即执行函数表达式(Immediately-Invoked Function Expression)

IFE 有两个比较经典的使用场景,一是类似于在循环中定时输出数据项,二是类似于 JQuery/Node 的插件和模块开发。

1
2
3
4
5
for
(
var
i = 0; i < 5; i++) {
 
setTimeout(
function
() {
 
console.log(i);
 
}, 1000);
}

上面的输出并不是你以为的0,1,2,3,4,而输出的全部是5,这时 IIFE 就能有用了:

1
2
3
4
5
6
7
for
(
var
i = 0; i < 5; i++) {
 
(
function
(i) {
 
setTimeout(
function
() {
 
console.log(i);
 
}, 1000);
 
})(i)
}

而在 JQuery/Node 的插件和模块开发中,为避免变量污染,也是一个大大的 IIFE:

1
2
3
(function($) {
 
//代码
 
} )(jQuery);

 

6、下面两个函数的返回值是一样的吗?为什么?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
function
foo1()
{
 
return
{
 
bar:
"hello"
 
};
}
 
function
foo2()
{
 
return
 
{
 
bar:
"hello"
 
};
}

在编程语言中,基本都是使用分号(;)将语句分隔开,这可以增加代码的可读性和整洁性。而在JS中,如若语句各占独立一行,通常可以省略语句间的分号(;),JS 解析器会根据能否正常编译来决定是否自动填充分号:

1
2
3
var
test = 1 +
2
console.log(test);
//3

在上述情况下,为了正确解析代码,就不会自动填充分号了,但是对于 return 、break、continue 等语句,如果后面紧跟换行,解析器一定会自动在后面填充分号(;),所以上面的第二个函数就变成了这样:

1
2
3
4
5
6
7
function
foo2()
{
 
return
;
 
{
 
bar:
"hello"
 
};
}

所以第二个函数是返回 undefined。

 

转载于:https://www.cnblogs.com/fangsmile/p/6289556.html

你可能感兴趣的文章
Python 模块调用和global的用法
查看>>
Ubuntu 12.04 修改/etc/resolv.conf重启后还原成修改前状态解决办法
查看>>
Python—redis
查看>>
HPE牵手DDN打造整合的高性能服务器存储产品组合
查看>>
mycat分片规则之范围约定规则(auto-sharding-long)
查看>>
windows配置java环境变量
查看>>
python流程处理
查看>>
<kubernetes in action>看书笔记
查看>>
python密码破解工具patator
查看>>
众筹网站Kickstarter不准备上市:转型公益企业
查看>>
OpenStack入门修炼之nova服务(计算节点)的部署与测试(11)
查看>>
ubuntu安装apache php mysql phpmyadmin
查看>>
漫画: DBA和小D的日常
查看>>
代码 实现UIDatePicker控件 和 Tab Bar 视图切换
查看>>
USB引导盘制作
查看>>
通过自己的项目实际经验,阐述为什么“恶心玩技术”?玩Java技术的教训(一)...
查看>>
蚂蚁分类信息系统 5.8 地区增加多级分类
查看>>
Spring-web源码解析之ContextLoaderListener
查看>>
设计模式--六大原则
查看>>
MONyog监控系统
查看>>