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

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

作者: jamesXiao_ | 来源:发表于2017-05-31 11:04 被阅读0次

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

  • 数值(number):整数和小数(比如1和3.14)
  • 字符串(string):字符组成的文本(比如"Hello World")
  • 布尔值(boolean):true(真)和false(假)两个特定值
  • undefined:表示“未定义”或不存在,即此处目前没有任何值
  • null:表示空缺,即此处应该有一个值,但目前为空
  • 对象(object):各种值组成的集合
  1. 数值、字符串、布尔值称为原始类型(primitive type)的值,即它们是最基本的数据类型,不能再细分了。

  2. 将对象称为复杂类型(complex type)的值,因为一个对象往往是多个原始类型的值的合成,可以看作是一个存放各种值的容器。

  3. 至于undefined和null,一般将它们看成两个特殊值。

typeof和instanceof的作用和区别?

  • typeof 和 instanceof 常用来判断一个变量是否为空,或者是什么类型的
  • typeof会返回一个变量的基本类型
  • instanceof返回的是一个布尔值
  • instanceof只能用来判断对象和函数,不能用来判断字符串和数字等

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

  • 使用typeof来判断类型
    “undefined” -- 这个值未定义
    “boolean” -- 这个值是布尔值
    “string ” -- 这个值是字符串
    “number” -- 这个值是数字
    “object” -- 这个值是对象或null
    “function” -- 这个值是函数

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

  • NaN含义是Not a Number,表示非数字,NaN和任何值都不相等,包括自己

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

  • 使用js转换函数 parseInt parseFloat
  • 使用强制类型转换 Number()
  • 使用运算符进行弱类型转换

==与===有什么区别

  • == 只判断数值,不判断类型相等
  • === 同时判断数值和类型是否相等

break与continue有什么区别

  • break 是跳出循环
  • continue 是单步跳过循环

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

  • undefined 可以在局部作用域中被覆写
  • void 运算返回值始终都是 undefined

以下代码的输出结果是?为什么?

console.log(1+1); 输出2,因为2个数字.+号是运算符
console.log("2"+"4"); 输出24,因为是2个字符串,+号代表连接符
console.log(2+"4"); 输出24,一个数字一个字符串,+号代表连接符
console.log(+"4"); 输出4, 进行了弱类型转换.


#以下代码的输出结果是?
>```
var a = 1;  
a+++a;  
typeof a+2;   typeof优先级高于+号,所以typeof a得到number ,然后+做字符串连接,,,最后是number2

以下代码的输出结果是? 为什么

var a = 1;
var b = 3;
console.log( a+++b ); a++是先计算,再自增,,所以是a+b,的到4


#遍历数组,把数组里的打印数组每一项的平方

>```
var arr = [3,4,5]
for(var i =0;i<arr.length;i++) {
  console.log (arr[i] * arr[i] ) ;
}

遍历 JSON, 打印里面的值

var obj = {
name: 'hunger',
sex: 'male',
age: 28
}
for (var i in obj) {
console.log (obj[i]);
}



#以下代码输出结果是? 为什么

>```
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val)  number2   先计算左边的到number2.左边为true,就忽略右边

var d = 5;
var data = d ==5 && console.log('bb')
console.log(data) undefined 左边为true,右边console.log不返回布尔,返回 undefined


>```
var data2 = d = 0 || console.log('haha')
console.log(data2) undefined  左边为0,0代表false,右边console.log返回undefined,,所以结果为undefined

var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x) 2 !!"Hello"为true (!"world", !!"from here!!") 逗号运算符返回后面的结果,,!!"from here!!"为true,,所以true+true 是2

相关文章

  • 2018-09-09

    java语法 包括 数据类型 、变量、运算符、流程控制语句、循环结构 1、数据类型 基本数据类型: ①浮点型(小数...

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

    数据类型运算符流程控制语句 一、JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类...

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

    数据类型运算符流程控制语句 JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型和...

  • Dart语法学习

    目录 参考资料 语言特性 关键字 变量与常量 数据类型 运算符 operators 控制流程语句 异常 Excep...

  • JS语法

    JavaScript基本概念、基础数据类型、运算符、流程控制语句。 一、CSS和JS在网页中的放置顺序是怎样的? ...

  • 关于Javascript语法

    * 这是关于JavaScript基本概念、基础数据类型、运算符、流程控制语句的一些小知识 * 1.CSS和JS在网...

  • 16.JS 语法

    学习内容:JavaScript基本概念,基础数据类型,运算符,流程控制语句 一、CSS和JS在网页中的放置顺序是怎...

  • Flutter之Dart语言 简述

    目录 变量声明 数据类型 关键字与运算符 流程控制语句 函数 变量声明 1. var var 类似于JavaScr...

  • 2018.10.31条件语句和循环语句

    流程控制语句 JS条件语句 通过条件来控制程序的走向,需要用到条件语句 运算符分类 明细算术运算符 +(加)...

  • 编程基础(掌握)

    常量与变量、数据类型、运算符、流程控制语句、方法、数组 *注释:用来解释说明代码的-->写代码一定要写注释 单行注...

网友评论

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

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