1 JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?
答:JavaScript定义了六种数据类型。分别是:
<li>数值(number):整数和小数。</li>
<li>字符串(string):字符组成的文本</li>
<li>布尔值(boolean):true和false两个值</li>
<li>undefined:表示未定义或不存在,即此处目前没有任何值</li>
<li>null:表示空缺,即此处应该有一个值,但目前为空</li>
<li>Object:对象,各种值组成的集合</li>
数值,字符串,布尔值为原始类型(primitive type)的值,即它们是最基本的数据类型,不能再细分了。将对象看作是复杂数据类型的值,因为一个对象往往是多个原始数据类型的的合成,可以看作是各种值的容器。原始类型和复杂类型在定义时的区别是原始类型直接赋值,对象定义时是引用。
2 typeof和instanceof的作用和区别?
答:type的作用是判断一个值的数据类型:
<pre>typeof 1// "number"
typeof "123" //"string"
typeof true // "boolean"
function f(){};
typeof f;//"function"
typeof undefined //"undefined"
typeof window //"object"
typeof {} //"object"
typeof [] ////"object"
typeof null //"object" </pre>
instanceof 用于一个变量是否属于某个对象的实例,运算符返回一个布尔值,而且区分数组与对象。
instanceof 只能用于判断对象和函数,不能用来判断字符串和数字等。
3 如何判断一个变量是否是数字、字符串、布尔、函数
答:typeof a === "number";typeof a === "string"; typeof a === "boolean";typeof a ==="function";
4 NaN是什么? 有什么特别之处?
答:表示not a number。NaN和任何值都不相等,包括它自己。在无法出现想要出现的数字结果时就以NaN代替。
5 如何把非数值转化为数值?
答:有三个函数可以将非数值转换成数值,1 Number(),2 parseInt(),3 parseFloat()。
6 ==与===有什么区别
答:==为近似相等,===为严格相等。使用==的时候,JavaScript会帮我们做类型上的转换,会造成一些预想不到的结果。
7 break与continue有什么区别
答:break上跳出循环体,执行下一条语句。continue为结束这次循环,进入下一次循环。
8 void 0 和 undefined在使用场景上有什么区别?
答:都可用于执行但返回值的情况下,但undefined不是关键字,因此有可能用户自定义了defined,会出现冲突,而void 0
不会出现这样的问题。
9 以下代码的输出结果是?为什么?
<pre>console.log(1+1); //2
console.log("2"+"4"); //24
console.log(2+"4"); //24
console.log(+"4"); //4
</pre>
10. 以下代码的输出结果是?
<pre>var a = 1;
a+++a; //输出结果2
typeof a+2;//输出结果为number2</pre>
11. 以下代码的输出结果是? 为什么
<pre> var a = 1;
var b = 3;
console.log( a+++b );//输出结果为4,因为a+++b运行时,先计算a++,结果为1,1+3为4,结束后a为2.</pre>
<h2>12. 遍历数组,把数组里的打印数组每一项的平方</h2>
<pre>var arr = [3,4,5];
//遍历数组,把数组里的打印数组每一项的平方
for(var i=0;i< arr.length;i+=1){
console.log(arr[i]*arr[i]);
}</pre>
<h2>13. 遍历 JSON, 打印里面的值</h2>
<pre>var obj = {
name: 'hunger',
sex: 'male',
age: 28
}</pre><pre>
//遍历 JSON,打印里面的值
for(key in obj){
console.log(key+":"+obj[a]);
}
</pre>
<h2>14. 以下代码输出结果是? 为什么 ?</h2>
<pre>
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) //number2 undefined
var d = 5;
var data = d ==5 && console.log('bb')
console.log(data) //bb undefined undefined
var data2 = d = 0 || console.log('haha')
console.log(data2) // haha undefined undefined
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x) //2 undefined
</pre>