javascript中的基本数据类型包括:

Undefined, Null, Boolean, Number, String 5种数据类型

1. Undefined 类型 (只有一个值 undefined, 常被用来表示未初始化的变量)

  • 如果一个变量未进行初始化则它的初始值为undefined, 数据类型为Undefined

var myVar;

myVar === undefined               // return true

typeof myVar === 'undefined'   // return true

  • 函数的参数列表中,未传入的实参的形参其值为undfined

function sum(a, b){

if(b === undefined) b = 0;

return a + b;

}

sum(1,2);     // return 3

sum(1);        // return 1, 其中第二个参数未传递值,则其值为undefined,

2. Null 类型 (只有一个值 null, 常被用来表示一个空对象指针)

  • 由于用来表示空对象,所以 typeof null === 'object'
  • 由于undefined 值派生自 null值,所以 null == undefined

3. Boolean 类型 (有两个值:true, false)

  • 数据类型转换使用 Boolean()

String:  Boolean('str'); // true

Boolean('');    // false

Number: Boolean(2);    // true

Boolean(0);    // false

Object:   Boolean({});  // true

Null:       Boolean(null); // false

Undefined: Boolean(undefined);  // false;

4. String 类型

  • 数据类型转换

var myVar = 5;

String(5);                //   return '5'   将任意类型转为字符串

myVar.toString();     //   return '5',  undefined 与 null 值没有此方法

myVar.toString(2);   //   return '101', 以二进制的形式返回

myVar += '';           //    return '5',  利用数据自动转换

 5. Number 类型

  • 浮点型 由于计算舍入误差 最好不要用在条件测试中
  • 整型    8进制在严格模式下无效
  • 最大值 Number.MAX_VALUE, 最小值 Number.MIN_VALUE
  • 正无穷大 Number.POSITIVE_INFINITY, 负无穷大 Number.NEGATIVE_INFINITY, 函数isFinite(value) 用于断定一个数值是否介于正无穷和负无穷之间
  • NaN 表示一个不是数值的值, 函数isNaN(value) 用于判断一个值进行数据类型转换后是不是 '不是数值'
  • 数据类型转换 Number() , parseInt(), parseFloat()

Number() : 可以转换任意类型的数据, 下面的表达式均返回true

Number(undefined) === NaN;

Number(null) === 0;

Number('34') === 34;

Number('34df') === NaN;

Number('') === 0;

Number(true)  === 1;

Number(false) === 0;

Number({})   === NaN;

parseInt(): 主要用于将字符串转换为整型类型, 第二个参数可以指定进制

parseInt(' 12df') === 12

parseInt('2.4dd') === 2

parseInt('') === NaN

parseInt('10', 10) === 10

parseInt('10', 2) === 2

parseFloat(): 用于将字符串转为浮点型数据,规则与parseInt相似,但没有第二个参数但,只能转为10进制浮点数

javascript 高级编程系列 - 基本数据类型的更多相关文章

  1. javascript 高级编程系列 - 函数

    一.函数创建 1. 函数声明 (出现在全局作用域,或局部作用域) function add (a, b) { return a + b; } function add(a, b) { return a ...

  2. javascript 高级编程系列 - 继承

    1. 原型链继承 (缺点:子类继承父类的引用类型的属性值会在各个实例中共享,创建子类实例时无法向父类构造函数传递参数) // 定义父类构造函数 function SuperClass(father, ...

  3. javascript 高级编程系列 - 创建对象

    1. 工厂模式 function createPerson(name, age) { var obj = {}; obj.name = name; obj.age = age; obj.getName ...

  4. javascript高级编程笔记01(基本概念)

    1.在html中使用JavaScript 1.  <script> 元素 <script>定义了下列6个属性: async:可选,异步下载外部脚本文件. charset:可选, ...

  5. JavaScript高级编程———JSON

    JavaScript高级编程———JSON < script > /*JSON的语法可以表达一下三种类型的值 简单值:使用与javas相同的语法,可以在JSON中表达字符串.数值.布尔值和 ...

  6. JavaScript高级编程———基本包装类型String和单体内置对象Math

    JavaScript高级编程———基本包装类型和单体内置对象 <script> var stringObject = new String("hello world") ...

  7. JavaScript高级编程——Date类型

    JavaScript高级编程——Date类型 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" ...

  8. JavaScript高级编程——Array数组迭代(every()、filter()、foreach()、map()、some(),归并(reduce() 和reduceRight() ))

    JavaScript高级编程——Array数组迭代(every().filter().foreach().map().some(),归并(reduce() 和reduceRight() )) < ...

  9. JavaScript高级编程——引用类型、Array数组使用、栈方法

    JavaScript高级编程——引用类型.Array数组使用.栈方法 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999 ...

随机推荐

  1. 九度oj 题目1465:最简真分数

    题目描述: 给出n个正整数,任取两个数分别作为分子和分母组成最简真分数,编程求共有几个这样的组合. 输入: 输入有多组,每组包含n(n<=600)和n个不同的整数,整数大于1且小于等于1000. ...

  2. HDU——1418抱歉(平面欧拉公式)

    抱歉 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submiss ...

  3. 免安装版MySql安装与配置

    1:在MySql官网下载免安装版 http://downloads.mysql.com/archives/community/ 下载链接 http://downloads.mysql.com/arch ...

  4. Linq技巧3——何时及怎么使用预先加载

    通常情况在你的应用程序中,一旦你要查询完数据的的时候,你知道使用实体来做什么. 假如你打印一份订单给顾客,你知道不包括组成订单的Items和Products信息,打印的信息是不完整的,所以查询时也需要 ...

  5. 标准C程序设计七---66

    Linux应用             编程深入            语言编程 标准C程序设计七---经典C11程序设计    以下内容为阅读:    <标准C程序设计>(第7版) 作者 ...

  6. Definition vs declaration

    #include <stdio.h> union test1; // declaration union test2 { // The definition of union test2 ...

  7. 容器中元素的去重——ans.erase(unique(ans.begin(),ans.end()),ans.end());

    啊,原来unique()函数,只是处理的连续的元素,比如 -1 -1 -1 1 2 -1 2 就处理成了 -1 1 2 -1 2 -1 -1并且返回5,之后eraser(5,7)剩下了 -1 1 2 ...

  8. js库-AngularJS

    我是一个不思进取的前端. 我想按部就班的工作. 我想得过且过. 老天呀!你咋又逼迫我学习对于我来说的新知识呢!!!!!!!我想哭呀!!!!! 在某个代码项目中我看到了{{??}}这么个标记!我的神呀! ...

  9. js-浅显基础-正则表达式集

    今天进博客园,忽然发现我也是有粉丝的人啦!!!!!!!!谢谢谢谢关注(爱心爱心) 本来不想做这个笔记的,但是每次都百度我自己都烦死了,所以还是自己整理一下方便我后期使用: 独笑笑不如众笑笑,放轻松点 ...

  10. Codeforces 919 C. Seat Arrangements

    C. Seat Arrangements   time limit per test 1 second memory limit per test 256 megabytes input standa ...