这里有新鲜出炉的 Javascript 教程,程序狗速度看过来!
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
js 中有六种数据类型,包括五种基本数据类型(Number,String,Boolean,Null,Undefined), 和一种混合数据类型(Object)。下面就跟着小编一起来看下吧
js 中有六种数据类型,包括五种基本数据类型(Number,String,Boolean,Null,Undefined), 和一种混合数据类型(Object)。
前面说到 js 中变量是松散类型的,因此有时候我们需要检测变量的数据类型。
typeof 操作符可以检测变量的数据类型(输出的是一个关于数据类型的字符串)。
返回如下 6 种字符串:number,string,boolean,object,undefined,function. 且看如下例子:
- 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。
- var name = "lijinwen";
- var age;
- console.log(name);//lijinwen
- console.log(age);//undefined
- //console.log(height);//error,变量height没有声明
- console.log(typeof name);//string
- console.log(typeof age);//undefined
- console.log(typeof height);//undefined,变量height没有声明
上面这段代码中,age 虽然声明了,但是没有初始化值,所以,打印出来的是 undefined. 而变量 height 没有声明,故报错。
但是用 typeof 操作符去检测数据类型的时候,变量 age 没有初始化,结果是 undefined,没有声明变量的 height 检测的类型也是 undefined.
6.Object 类型
js 中对象是一组属性与方法的集合。具体的关于对象的创建方式以及对象的各种特性,会在后面的引用类型的章节中 做详细介绍。这里就简单介绍一下六大数据类型中的 Object.
①constructor 属性:构造函数属性, 可确定当前对象的构造函数。
- var o = new Object();
- console.log(o.constructor == Object); //true
- var arr = new Array();
- console.log(arr.constructor == Array); //true
②hasOwnProperty(propertyName):判断属性是否存在于当前对象实例中(而不是原型对象中)。这个在后面的面向对象的章节中 有详细的讲解。
③… 更多关于 Object 请查看后面的章节面向对象。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持 phperz!
来源: http://www.phperz.com/article/17/0613/329111.html