js数据类型

责编:menVScode 2018-01-26 20:33 阅读(577)

        js中有六种数据类型,包括五种基本数据类型(Number,String,Boolean,Undefined,Null),和一种复杂数据类型(Object)。

        typeof 操作符

        由于js中的变量是松散类型的,所以它提供了一种检测当前变量的数据类型的方法,也就是typeof关键字。

var x = 1;
console.log(typeof x);//number
 
var a = undefined;
console.log(typeof a);//undefined
 
var b = null;
console.log(typeof b);//object,(null是空对象引用/或者说指针)。
 
var c = new Object();
console.log(typeof c);//object
 
var e = [1,2,3];
console.log(typeof e);//object 
 
var d = function(){
 // ... 语句块
}
console.log(typeof d);//function

        上面代码中,null类型进行typeof操作符后,结果是object,原因在于,null类型被当做一个空对象引用。

        1. Number类型

        Number类型包含整数和浮点数(浮点数数值必须包含一个小数点,且小数点后面至少有一位数字)两种值。

        浮点数将会自动转换为整数。

var num = 1.00;
console.log(num);//1,自动转换为整数

        浮点数的最高精度是17位,看下面的例子,结果竟然不是0.3,至于其他编程语言,也会遇到这种情况(关于浮点数计算会产生舍入误差问题,其他有些编程语言也会出现类似情况。)

var num1 = 0.1;
var num2 = 0.2;
console.log(num1 + num2);//0.30000000000000004

        NaN: 非数字类型。特点:① 涉及到的 任何关于NaN的操作,都会返回NaN   ② NaN不等于自身。

var ab = "a1";
console.log(ab/10);// NaN
console.log(NaN == NaN);// false;

        isNaN()函数,用于判断是否是一个非数字类型。如果传入的参数是一个非数字类型,那么返回true;否则返回false;

        isNaN()函数,传入一个参数,函数会先将参数转换为数值。

        如果参数类型为对象类型,会先调用对象的valueOf()方法, 再确定该方法返回的值是否可以转换为数值类型。如果不能,再调用对象的toString()方法,再确定返回值。

        数值转换:

        Number()转型函数,可以用于任何数据类型;

        parseInt(),将值转换为整型,用的比较多;

        parseFloat();将值转换为浮点型。

        2. String类型

        字符串类型中的单引号与双引号的作用效果完全一样。

        字符串有length属性。可以取得字符串的长度。var str = 'hello'; console.log(str.length); //5

        字符串的值是不可变的。要改变一个字符串的值,首先要销毁原来的字符串,再用另一个包含新值的字符串去填充该字符串。

var lang = “java”;
lang += “script”;

        上面这段代码,先创建一个能容纳10个字符的字符串,然后在这个字符串中填充java和script字符串,最后销毁原来的字符串java和scrip字符串,因为这两个字符串此时已经没用了。这个个过程是在后台发生的。

        字符串转换:转型函数String(),适用于任何数据类型(null,undefined 转换后为null和undefined);toString()方法(null,defined没有toString()方法)。

var bc = "lijinwen";
var bd = null;
var be = undefined;
console.log(bc.toString());
//console.log(bd.toString());//error 报错
//console.log(be.toString());//error 报错
console.log("------");
console.log(String(bc));
console.log(String(bd));
console.log(String(be));

        3. Boolean类型

        该类型只有两个值,true和false

        转换为boolean值: 转型函数Boolean(),将某个值转换为Boolean类型。详细内容,后面会慢慢的补充。

        4. Null类型

        null类型被看做空对象指针,前文说到null类型也是空的对象引用。只有一个值,即null值,所以,在你 用typeof 操作符去检测null类型的值时,结果是object类型。

        如果你定义了一个变量,但是想在以后把这个变量当做一个对象来用,那么最好将该对象初始化为null值。

        5. Undefined类型

只有一个值,即undefined值。使用var声明了变量,但未给变量初始化值,那么这个变量的值就是undefined。

        

        三大引用类型

        1. Object类型

        我们看到的大多数类型值都是Object类型的实例,创建Object实例的方式有两种。

        第一种是使用new操作符后跟Object构造函数,如下所示

var person = new Object();
person.name = "Micheal";
person.age = 24;

        第二种方式是使用对象字面量表示法,如下所示

var person = {
  name : "Micheal",
  age : 24
};

        2. Array类型

        数组的每一项可以用来保存任何类型的数据,也就是说,可以用数组的第一个位置来保存字符串,第二个位置保存数值,第三个位置保存对象....另外,数组的大小是可以动态调整的。

        创建数组的基本方式有两种

        第一种是使用Array构造函数,如下所示

var colors = new Array("red","blue","yellow");

        第二种是使用数组字面量表示法,如下所示

var colors = ["red","blue","yellow"];

        3. Function类型

        每个函数都是Function类型的实例,而且都与其他引用类型一样具有属性和方法。函数通常是使用函数声明语法定义的,如下所示

function sum(num1,num2){
  return num1 + num2;
};

        这和使用函数表达式定义函数的方式相差无几。

var sun = function (){
  return sum1 + sum2;
};
标签: 数据类型 js
前端交流群: MVC前端网(menvscode.com)-qq交流群:551903636

邮箱快速注册

忘记密码