JavaScript数据类型运算符流程控制语句

JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?

JavaScript的数据类型,共有七种。

  • 数值(number):整数和小数(比如1和3.14)
    // var num = 100;
  • 字符串(string):字符组成的文本(比如"Hello World")
    // var str = 'hello';
  • 布尔值(boolean):true(真)和false(假)两个特定值
    // var isOK = true;
  • undefined:表示“未定义”或不存在,即此处目前没有任何值
    // var hello; undefined
  • null:表示空缺,即此处应该有一个值,但目前为空
    // var empty= null;
  • 对象(object):各种值组成的集合
    // var person = {
    name: ' abc',
    age: 100;
    }
  • Symbol

原始类型

数值、字符串、布尔值称为原始类型(primitive type)的值,即它们是最基本的数据类型,不能再细分了。

复杂类型

将对象称为复杂类型(complex type)的值,因为一个对象往往是多个原始类型的值的合成,可以看作是一个存放各种值的容器。
至于undefined和null,一般将它们看成两个特殊值。

原始类型和复杂类型的区别是什么?

  1. 基本类型变量存的是值,复杂类型的变量存的是内存地址。

  2. 基本类型在赋值的时候拷贝值,复杂类型在赋值的时候只拷贝地址,不拷贝值。

typeof和instanceof的作用和区别?

typeof的作用

  • typeof是一元运算符,返回值为字符串,该字符串用来说明运算数的数据类型
    typeof 用以获取一个变量的类型,一般只能返回如下几个结果:
    number,boolean,string,function,object,undefined。
    数值、字符串、布尔值分别返回number、string、boolean。

    typeof 123 // "number"
    typeof '123' // "string"
    typeof false // "boolean"
    

    函数返回function。

    function f() {}
    typeof f
    

    undefined返回undefined。

    typeof undefined
    

    利用这一点,typeof可以用来检查一个没有声明的变量,而不报错。

    v  // ReferenceError: v is not defined
    typeof v // "undefined"
    

    实际编程中,这个特点通常用在判断语句。

    // 错误的写法
    if (v) { }  // ReferenceError: v is not defined
    // 正确的写法
    if (typeof v === "undefined") { }  
    

    除此以外,其他情况都返回object。

    typeof window // "object"
    typeof {} // "object"
    typeof [
    

![Uploading 5-5_380537.jpg . . .]
] // "object"
typeof null // "object"

instanceof的作用

  • instanceof 是一个二元运算符,用于判断某个变量是否是某个对象的实例,返回值为true或false。左边a是被运算的值,右边b是运算的类型。格式是这样的:

    a instanceof b
    

    返回结果是布尔值(Boolean):true/false

区别:
instanceof是一个判断,而typeof是求值。

NaN是什么? 有什么特别之处?

NaN含义是Not a Number,表示非数字,NaN和任何值都不相等,包括自己

  NaN === NaN
  // false

如何把非数值转化为数值?

在JavaScript中,有3个函数可以把非数值转换为数值,这三个函数分别是:Number() 、parselnt() 和 parseFloat()。第一个函数,即转型函数 Nurnber() 可以用于任何数据类型,而另两个函数则专门用于把字符串转换成数值。这3个函数对于同样的输入会返回不同的结果。

==与===有什么区别

可以使用==或===判断两个值的相等性,===是严格意义的相等,只需注意NaN和NaN不等就行了。而使用==的时候,javascript会帮我们做类型转换,造成一些匪夷所思的结果,那么使用==的时候会在哪些情况下做类型转换,又会换成什么样子?
1、如果两个值类型相同,则执行严格相等的运算;
2、如果两个值的类型不同:
如果一个是null,一个是undefined,那么相等;
如果一个是数字,一个是字符串,先将字符串转为数字,然后比较;
如果一个值是true/false则将其转为1/0比较;
如果一个值是对象,一个是数字或字符串,则尝试使用valueOf和toString转换后比较
其它就不相等了;


JavaScript数据类型运算符流程控制语句_第1张图片
== 测试.jpg

break与continue有什么区别

  • break 用于强制退出循环体,执行循环后面的语句;
  • continue 用于退出本次循环,执行下次循环;

void 0 和 undefined在使用场景上有什么区别

  • undefined 不能被重写。但是在局部作用域中,还是可以被重写的
    所以undefined现常用于全局环境
  • void 运算符通常只用于获取 undefined 的原始值,一般使用 void(0)(等同于 void 0)。在上述情况中,也可以使用全局变量undefined 来代替(假定其仍是默认值)。
    void 可以给任何给定的表达式求值,并返回 undefined,并且void 不可被重写,因此void 0是在局部作用域中替代undefined的最佳选择;

以下代码的输出结果是?为什么?

代码1.jpg
JavaScript数据类型运算符流程控制语句_第2张图片
代码1答案.jpg

以下代码的输出结果是?为什么?

代码2.jpg
JavaScript数据类型运算符流程控制语句_第3张图片
代码2答案-2.jpg

以下代码的输出结果是?为什么?

代码3.jpg
JavaScript数据类型运算符流程控制语句_第4张图片
代码3答案.jpg

遍历数组,把数组里的打印数组每一项的平方

代码4.jpg
JavaScript数据类型运算符流程控制语句_第5张图片
代码4答案.jpg

遍历 JSON, 打印里面的值

代码5.jpg
JavaScript数据类型运算符流程控制语句_第6张图片
代码5答案.jpg

以下代码输出结果是? 为什么?

JavaScript数据类型运算符流程控制语句_第7张图片
代码6.jpg
JavaScript数据类型运算符流程控制语句_第8张图片
代码6答案.jpg

你可能感兴趣的:(JavaScript数据类型运算符流程控制语句)