美文网首页
js数据类型运算符流程控制语句

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

作者: 727上上上 | 来源:发表于2017-09-21 16:20 被阅读0次

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

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

    • number:整数和小数
    • string:字符串组成的文本
    • boolear:true和false两个特定的值
      复杂类型,一个对象由多个原始数据组成的合集
    • object: 各种值组成的集合(又能分为function,arry,regexp)
      特殊值:
    • null:空缺,即此处应该有个值,但目前为空
    • undefined:未定义或不存在,即此处没有任何值

    typeof和instanceof的作用和区别?

    • typeof是一个一元运算符,运算格式为typeof a,会返回1个字符串来判断数据基本类型是什么,可返回的字符串为:number,boolear,string,undefined,function,object(对象为arry,null等特殊值时一律返回object,这也是typeof的局限性)。
      还可以用来判断变量是不是已经被定义,通常一个变量未被定义就拿来使用会报错,但是又需要知道一个变量是否存在,而typeof可以提供这样的能力:if(typeof a!="undefined"){}
    • 要获取一个对象是否是数组,或判断某个变量是否是一个对象的实例时则要选择使用instanceof(不属于object类型的基本类型是无法应用instanceof的,或者无法得到想要的结果)。instanceof是一个二元运算符,运算格式为a instanceof b,左边是运算的值,右边是运算的类型,返回的结果为布尔值true/false。

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

    使用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() 只解析十进制,因此它没有第二个参数指定基数的用法

    ==与===有什么区别

    • ===是完全相等,除了NaN和NaN不等;
    • ==是相等,但是当类型不同是会做类型转换然后比较:
      如果一个是null,一个是undefined,那么相等
      如果一个是数字,一个是字符串,先将字符串转为数字,然后比较
      如果一个值是true/false则将其转为1/0比较
      如果一个值是对象,一个是数字或字符串,则尝试使用valueOf和toString转换后比较
      其它的值不相等

    break与continue有什么区别

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

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

    • undefined 不能被重写。但是在局部作用域中,还是可以被重写的。
      所以undefined现常用于全局环境
    • void 运算符通常只用于获取 undefined 的原始值,该操作符指定要计算一个表达式但是不返回值。也可以使用全局变量undefined 来代替(假定其仍是默认值)。
      而void 可以给任何给定的表达式求值,并返回 undefined,并且 void 不可被重写,因此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
    

    相关文章

      网友评论

          本文标题:js数据类型运算符流程控制语句

          本文链接:https://www.haomeiwen.com/subject/llqtextx.html