1.JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型
和复杂类型的区别是什么?
数据类型:字符串(string)、数值(number)、布尔(boolean)、undefined、null、对象(object)
数值、字符串、布尔值称为原始类型(primitive type)的值,即它们是最基本的数据类型,不能再细分了。
对象称为复杂类型(complex type)的值,因为一个对象往往是多个原始类型的值的合成,可以看作是一个存放各种值的容器。
undefined和null,一般将它们看成两个特殊值。
2.typeof和instanceof的作用和区别?
typeof是一元运算符,返回值为字符串,该字符串用来说明运算数的数据类型;
用来获取运算数的数据类型。返回的值有number、boolean、undefined、function、object、string。
var a="zhangqian";
var b=10;
var c=true;
var d;
var e=null;
var f=new Object();
var g=function(){}
console(typeof a); //string
console(typeof b); //number
console(typeof c); //boolean
console(typeof d); //undefined
console(typeof e); //object
console(typeof f); //object
console(typeof g);//function
instanceof用于判断某个变量是否是某个对象的实例,返回值为true或false
var array=new Array();
var object=new Object();
var regexp=new RegExp();
function func(){};
var func1=new func();
alert(array instanceof Array); //true
alert(object instanceof Object); //true
alert(regexp instanceof RegExp); //true
alert(func1 instanceof func); //true
其实typeof和instanceof的目的都是检测变量的类型,两个的区别在于typeof一般是检测的是基本数据类型,instanceof主要检测的是引用类型!
3. 如何判断一个变量是否是数字、字符串、布尔、函数
使用typeof运算符即可:
var a="zhangqian";
var b=10;
var c=true;
var d=function(){}
console(typeof a); //string
console(typeof b); //number
console(typeof c); //boolean
console(typeof d);//function
4.NaN是什么? 有什么特别之处?
"Not a Number" 即非数值,是一个特殊的数值,这个数值用于表示一个本来要返回数值的操作书未返回数值的情况(这样就不会抛出错误了)。例如,在其他编程语言中,任何数值除以非数值都会导致错误,从而停止代码执行。但在ECMAScript中,任何数值除以非数值会返回NaN,因此不会影响其他代码的执行。
特别之处:任何NaN的值进行操作都会返回一个NaN;NaN与任何值都不相等即NaN === NaN也是false.
5.如何把非数值转化为数值?
Number()、parseInt()、或者parseFloat()。解析规则,只突出两个点,一个是空字符串是转换成0的,其次当我们使用类似于parseInt的时候可以向函数传递第二个参数如parseInt(a,8),即调用8进制来解析。
6. ==与===有什么区别
== 相等
=== 严格相等
两等号判等会在比较时进行类型转换;三等号判等不会进行类型转换(如果类型不同会直接返回 false )。
7.break与continue有什么区别
break 用于强制退出循环体,执行循环后面的语句;
continue 用于退出本次循环,执行下次循环。
8.void 0 和 undefined在使用场景上有什么区别
- undefined 在 ES5 中已经是全局对象的一个只读(read-only)属性了,它不能被重写。但是在局部作用域中,还是可以被重写的。
- void 运算符通常只用于获取 undefined 的原始值,一般使用 void(0)(等同于 void 0)。在上述情况中,也可以使用全局变量undefined 来代替(假定其仍是默认值)。
而 void 可以给任何给定的表达式求值,并返回 undefined,并且 void 不可被重写,因此void 0是在局部作用域中替代undefined的最佳选择
9.以下代码的输出结果是?为什么?
console.log(1+1); //2,两个数字加法运算
console.log("2"+"4"); //"24",两个字符串类型的做字符串拼接
console.log(2+"4"); //"24",一个是数字一个是字符串,数字转化为字符串后拼接
console.log(+"4");//4,只有一个字符串会转换成数字输出
10.以下代码的输出结果是?
var a = 1;
a+++a; //3
typeof a+2;//"number2"
11. 以下代码的输出结果是? 为什么
var a = 1;
var b = 3;
console.log( a+++b );//4,++运算优先于+运算,理解为(a++)+b,a++结果为1,运算为1+3=4。
12. 遍历数组,把数组里的打印数组每一项的平方
var arr = [3,4,5];
for(var i=0;i<arr.length;i++){
console.log(arr[i]*arr[i]);
};
输出结果:9,16,25
13. 遍历 JSON, 打印里面的值
var obj = {
name: 'hunger',
sex: 'male',
age: 28
}
for(var key in obj){
console.log(a+":"+obj[key]);
};
输出结果: name: 'hunger', sex: 'male', age: 28
14. 以下代码输出结果是? 为什么 (选做题目)
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) //number2,只要“||”前面为true,无论“||”后面是true还是false,结果都返回“||”前面的值。最后将"number2"赋值给val;
var d = 5;
var data = d ==5 && console.log('bb')
console.log(data)//bb,(d ==5) && 'bb' => 'bb'
var data2 = d = 0 || console.log('haha')
console.log(data2)//haha,
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x)//2,!"world"为false, !!"from here!!"为ture, !!"Hello"为ture,
所以ture+ture, 输出为2