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

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

JavaScript的数据类型有七种:数值(number)、字符串(string)、布尔值(bool)、undefined、null、对象(object)、Symbol(ECMAScript 6 新定义,表示唯一值)
原始类型:数值(number)、字符串(string)、布尔值(bool)
复杂类型:对象(object)
对象:狭义的对象、数组(array)、函数(function)、正则表达式(regexp)
特殊值: undefined 未定义或不存在的值,没有任何值;null 空值,表示有值,值是空的。
区别:原始类型是最基本的数据类型,不能再细分;复杂类型是多个原始类型的值的合成,可以看成一个存放各种值的容器。

2.typeof与instanceof的作用和区别?

typeof的作用是返回一个值的数据类型,返回的结果是:number、string、boolean、undefined、object、function

instanceof作用是判断一个对象是不是由某个构造函数创建的实例。返回结果是true或false

3.如何判断一个变量是否是数字、字符串、布尔、函数
    var a=123;
    var b="hello";
    var c=false;
    function f() {}
    typeof a   ---number
    typeof b   ---string
    typeof c   ---boolean
    typeof f   ----function
4.NaN是什么?有什么特别之处?

NaN 含义是Not a Number,但它本身是一个数值类型,表示非数字值的特殊值。NaN与其他数值进行比较的结果总是不相等的,包括它本身在内。

    typeof NaN            ---number
    typeof NaN === NaN    ---false
    typeof NaN !== NaN    ---true
    parseInt('abc')      ---NaN
5.如何把非数值转换成数值?

有三个函数可以把非数值转换成数值
Number()函数、parseInt() 函数、parseFloat()函数
注意:
(1)忽略字符串前面的空白字符,找到第一个非空白字符。
(2)如果第一个字符不是-或者数字返回NaN
(3)继续解析,直到是非数值模式为止
(4)0开头会当成八进制,0x开头会当成十六进制,但是可以指定第二个参数指定基数。

   Number('13')        //13
   Number('13a')      //NaN
   parseInt('blue');   //NaN
   parseInt('12a')     //12
   parseInt('-23a');   // -23
   parseInt('0xf1');   // 241
   parseInt('101', 2); // 5
   parseFloat('12.3')  //12.3
   parseFloat('1.2a')  //1.2  
6.==与===有什么区别

==近似相等,比较值是否相等
===绝对相等,比较类型和值都要相等

  undefined == null     //true
  undefined === null    //false
  NaN == NaN       //false
  NaN === NaN      //false
  "1" == true     //true
  "1" === true    //false
7.break和 continue有什么区别

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

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

void执行一个表达式返回undefined,在某些情况下,undefined是可以被赋值的,比如在函数中,就不能用undefined来进行判断了,所以就可以用void 0 返回undefined来进行判断

9.以下代码的输出结果是什么?为什么?
  console.log(1+1);       //2
  console.log("2"+"4");   //24
  console.log(2+"4");     //24
  console.log(+"4");      //4
输出结果 原因
2 两个操作数都是数字,做加法运算
24 两个操作数都是字符串,字符串拼接
24 把数字2转换成字符串"2",然后字符串拼接
4 只有一个字符串参数的时候会尝试将其转化为数字
10.以下代码的输出结果是什么?
  var a = 1;       //undefined
  a+++a;          // 3   相当于(a++)+a,++的优先级高于+
  typeof a+2;   //"number2"

输出结果:"number2" ,typeof的运算优先级高于+,先计算typeof a,typeof a 的返回结果是"number" ,然后将数字2转换成字符串"2",最后字符串拼接

11.以下代码的输出结果是什么?为什么
 var a = 1;     //undefined
 var b = 3;    //undefined
 console.log(a+++b);

输出结果:4,++的运算优先级高于+,相当于(a++)+b,自增a++是先赋值再加1,所以先执行a+b=4,然后执行a++=2

12.遍历数组,把数组里的打印数组每一项的平方
 var arr = [3,4,5]

遍历数组用for循环

 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-in循环

for (var key in obj){
  console.log(obj[key]);
}
输出结果:  hunger  male  28
14.以下代码输出结果是什么?为什么
  var a = 1, b = 2, c = 3;    //undefined
  var val = typeof a + b || c >0     //undefined
  console.log(val)        //number2 
 
  (1)根据运算符优先级先算 typeof a,a=1是数字,结果为"number"
  (2)然后计算+b,b=2,所以结果为"number2"
  (3)c>0 为true,计算 "number2" || true
  (4)输出结果number2

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

  (1) 根据优先级 var data=(d==5)&&console.log('bb'),先计算d==5,结果为true
  (2) console.log('bb'),输出bb,结果是undefined
  (3) true && undefined,结果是undefined
  (4)输出结果undefined

  var data2 = d = 0 || console.log('haha')    //haha  
  console.log(data2)     //undefined 

  (1) 根据优先级 console.log('haha'),输出haha,结果是undefined
  (2) || 的优先级高于=,计算 0 || undefined,结果是undefined
  (3)输出结果undefined

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

  (1)根据优先级先计算小括号里的(!"world", !!"from here!!"),计算!"world",结果为false;计算 !!"from here!!",结果为true
  (2)计算(false,true),结果为true
  (3)true+true,结果为2,当+两边都是boolean,会把boolean转换成number,true==1,false==0,true+true结果为2
  (4)输出结果2
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容