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

2017-09-21  本文已影响0人  727上上上

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

原始类型,即最基本的数据类型,已经不能在细分了:

typeof和instanceof的作用和区别?

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

使用typeof,是数字时返回number,是字符串时返回string,是布尔值时返回boolear,是函数时返回function。

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

Not a Number,非数字,NaN和任何值都不相等,包括自己。

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

  1. Number()会转换整个值
    如果是Boolean值,true和false值将分别被转换为1和0。
    如果是数字值,只是简单的传入和返回。
    如果是null值,返回0。
    如果是undefined,返回NaN。
    如果字符串中只包含数字时,将其转换为十进制数值,忽略前导0
    如果字符串中包含有效浮点格式,如“1.1”,将其转换为对应的浮点数字,忽略前导0
    如果字符串中包含有效的十六进制格式,如“0xf”,将其转换为相同大小的十进制数值
    如果字符串为空,将其转换为0
    如果字符串中包含除上述格式之外的字符,则将其转换为NaN
    如果是对象,则调用对象的valueOf()方法,然后依照前面的规则转换返回的值。如果转换的结果是NaN,则调用对象的toString()方法,然后再依照前面的规则转换返回的字符串值。
  2. parseInt()用于处理整数时使用(即转换部分值)
    如果字符串头部有空格,空格会被自动去除;
    如果parseInt的参数不是字符串,则会先转为字符串再转换;
    如果是继续解析,直到非数值模式(包括小数点)为止,
    0开头会当做八进制,0x开头会当做十六进制,但是可以指定第二个参数指定基数
  3. parseFloat()
    与paeseInt()类似但是字符串中第一个小数点是有效的,而第二个小数点就是无效的了,它后面的字符串将被忽略。
    parseFloat() 只解析十进制,因此它没有第二个参数指定基数的用法

==与===有什么区别

break与continue有什么区别

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

console.log(1+1);  //2              两个数字相加做加法运算
console.log("2"+"4"); //"24"     两个字符串做字符串拼接
console.log(2+"4"); /"24"         有一个字符串时会把另个参数转化为字符串做字符串拼接
console.log(+"4");//4                一个字符串参数的时候会尝试将其转换为数字
var a = 1;  
a+++a;  
typeof a+2;//"number2"           typeof优先级比+高,相当于(typeof a)+2,即"number"+2
 var a = 1;
 var b = 3;

 console.log( a+++b );//4        ++优先级比+高,即(a++)+b
 var arr = [3,4,5]
for(var i=0; i < arr.length;i++){
       console.log(arr[i])
}
3
4
5
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) //number2                     
                               number + b || true  ->   number + b

var d = 5;
var data = d ==5 && console.log('bb')
console.log(data)//undefined                        
                                              (d==5)&& consolo.log('bb')

var data2 = d = 0 || console.log('haha')
console.log(data2)//undefined                         
                                            d = ( 0 || console.log('haha'))
 
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x)//2                         
                                                   x= true + true
上一篇下一篇

猜你喜欢

热点阅读