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

Q: JS的数据类型有几种?哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?

A: JS的数据类型有6种,分别是number,string,boolean,null 、undefined、object。 前三者是原始类型。

null和undefined属于两个比较特殊的数据类型,null 表示空,undefined表示未定义,区分二者意义不大,大多数情况下,我们应该使用null,undefined多用于判断函数参数是否传递的情况下。

对象称为复杂类型( complex type) ,因为一个对象往往是多个原始类型组成的无序集合,object又可以细分为Array (数组),funcation(函数),regexp(正则表达式)。

原始类型和复杂类型的区别?
1.特性区别
原始值是固定而简单的值,他们也不再细化了,数字类型就是数字,字符就是字符,布尔值就是ture或者false,null和undefined就是他们本身。这些值比较简单。
复杂值可以由很多简单值组成。
2.存储方式区别
原始值占据空间固定,存储在栈(stack)中。
复杂值的大小会改变,所以不能放在栈中,否则会降低查询速度,因此储存在堆(heap)中,存储在变量处的值是一个指针,指向存储对象的内存处。
3.访问方式的区别
原始值,按值访问,引用他们会转移其值。
复杂值是通过引用进行存储和操作的,而不是实际的值。创建一个包含复杂对象的变量时,其值是内存中的一个引用地址。引用一个复杂对象时,使用他的名称(变量或对象属性)通过内存中的引用地址获取值。
4.比较方式的区别
原始值采用值比较,而复杂值采用引用比较。复杂值只有在引用相同的对象(即有相同的地址)时才相等。即使是包含相同对象的两个变量也彼此不相等,因为他们并不会指向同一个对象?
5.动态属性的区别
对于复杂值,可以添加属性和方法,也可以改变和删除其属性和方法。更新变量以后,所有指向该对象的变量都会得到更新。一个变量指向复杂值时,并没有复制复杂值,只是引用。
6.包装类型的区别。
原始值被当做构造函数创建的一个对象使用时,JS会将其转换成一个对象,以便可以使用对象的特性和方法,而后抛弃对象性质,并将它变回原始值。

Q:typeof和instanceof的区别?

A: typeof运算符是返回数据类型。可以是number,string,boolean.
函数则返回funcation,undefined返回undefined.除此之外,其他情况都会返回object.

instanceof 是用来判断一个变量是否是某一个变量的实例,返回的是boolean。

Q: 如何判断一个变量是否一个数字、字符串、布尔、函数。

A: typeof 变量名;

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

A:NaN含义是 Not a number,但是他本身的数据类型仍然是个number;
NaN和任何值都不相等,包括他自己。
唯一能判断NaN的方法是通过isNaN()函数。

Q:如何把非数值转换为数值

A: 有三个函数,可以把非数值转换为数值。
Number();
parselnt();
parseFloat();
其中,parseInt()和 parseFloat()转换的时候,如果字符串不是以 " - ",

Q: "=="和 "==="有什么区别?

A: 都是比较两个值是否相等的运算符,如果两个数据类型不一样的值,"=="会将两边的值,转换成同一数据类型,再比较。"==="是严格运算符,不会转换数据类型,数据类型不一样,会直接返回false.

Q: break和continue有什么区别。

A: break,跳出代码块或者循环,执行之后的内容。
continue,终止本次循环,回到循环体的头部,开始下一轮循环。

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

A:void 后面加表达式,无论表达式计算结果是什么,都返回undefined;
利用这个特性,我们可以在避免undefined在被赋值的情况,无法判断一个变量是否是undefined,例如

fucation abcd(){
  undefined=3;
  var a;
  if(a===undefined){
    console.log('true');
  }
}
abc()

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

A:

console.log(1+1) //结果2; 数学运算。
console.log("2"+"4") //结果"24";字符串相加,
console.log(2+"4") //结果"24";一个字符串和一个数字相加,结果是字符串
console.log(+"4") //结果4;只有一个字符串结果就是,数字。

Q:以下代码输出结果。

A:

var a=1;
a+++a; //等于 (a++)+a=1+2=3;
typeof a+2; // (typeof a)+2=numeber+2="number2";

Q:以下代码输出结果。

A:

var a=1;
var b=3;
console.log(a+++b); //4,a+++b=(a++)+b=4;

Q:遍历数组,打印里面的值的平方。

A:

JS 数据类型、运算符、流程控制语句_第1张图片
a

Q:遍历JSON,打印里面的值。

A:


JS 数据类型、运算符、流程控制语句_第2张图片
B

Q:以下代码输出结果是?

A:

var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) // 结果是'number2'  左边真,返回左边值。

var d = 5;
var data = d ==5 && console.log('bb')
console.log(data) // 'bb'  undefined &&左边为真,计算右边值,返回右边值,console.log('bb')的返回值是undefined

var data2 = d = 0 || console.log('haha')
console.log(data2) // 'haha' undefined 假||真,返回第二个值,不是布尔值。console.log('haha')的返回值其实是undefined

var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x) // ture+ture=2

或要真值,且要假值,否则都返回右边的值

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