详解js的六大数据类型


Posted in Javascript onDecember 27, 2016

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请查看后面的章节面向对象。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
更正确的asp冒泡排序
May 24 Javascript
JavaScript入门教程(9) Document文档对象
Jan 31 Javascript
extjs 如何给column 加上提示
Jul 29 Javascript
webapp框架AngularUI的demo改造之路
Dec 21 Javascript
jQuery实现tag便签去重效果的方法
Jan 20 Javascript
Bootstrap每天必学之折叠(Collapse)插件
Apr 25 Javascript
JavaScript+CSS相册特效实例代码
Sep 07 Javascript
Three.js如何用轨迹球插件(trackball)增加对模型的交互功能详解
Sep 25 Javascript
vue .js绑定checkbox并获取、改变选中状态的实例
Aug 24 Javascript
深入理解Angularjs 脏值检测
Oct 12 Javascript
详解element上传组件before-remove钩子问题解决
Apr 08 Javascript
Electron+vue从零开始打造一个本地播放器的方法示例
Oct 27 Javascript
javascript ASCII和Hex互转的实现方法
Dec 27 #Javascript
谈谈第三方App接入微信登录 解读
Dec 27 #Javascript
JavaScript trim 实现去除字符串首尾指定字符的简单方法
Dec 27 #Javascript
修改ligerui 默认确认按钮的方法
Dec 27 #Javascript
js判断一个字符串是以某个字符串开头的简单实例
Dec 27 #Javascript
浅谈Vue的基本应用
Dec 27 #Javascript
利用Angularjs中模块ui-route管理状态的方法
Dec 27 #Javascript
You might like
全国FM电台频率大全 - 22 重庆市
2020/03/11 无线电
php图片加中文水印实现代码分享
2012/10/31 PHP
php实现插入排序
2015/03/29 PHP
WordPress中对访客评论功能的一些优化方法
2015/11/24 PHP
IE和Mozilla的兼容性汇总event
2007/08/12 Javascript
JavaScript 动态添加表格行 使用模板、标记
2009/10/24 Javascript
jQuery实现切换页面布局使用介绍
2011/10/09 Javascript
Jquery倒数计时按钮setTimeout的实例代码
2013/07/04 Javascript
jquery实现导航固定顶部的效果仿蘑菇街
2014/10/22 Javascript
js实现仿QQ秀换装效果的方法
2015/03/04 Javascript
JQuery+CSS实现图片上放置按钮的方法
2015/05/29 Javascript
jquery插件uploadify实现带进度条的文件批量上传
2015/12/13 Javascript
JavaScript中使用数组方法汇总
2016/02/16 Javascript
jQuery自适应轮播图插件Swiper用法示例
2016/08/24 Javascript
超全面的vue.js使用总结
2017/02/12 Javascript
基于Vue的移动端图片裁剪组件功能
2017/11/28 Javascript
微信小程序实现倒计时补零功能
2018/07/09 Javascript
layui自定义ajax左侧三级菜单
2019/07/26 Javascript
使用IPython来操作Docker容器的入门指引
2015/04/08 Python
一篇文章入门Python生态系统(Python新手入门指导)
2015/12/11 Python
Python 中pandas.read_excel详细介绍
2017/06/23 Python
Python实现将MySQL数据库表中的数据导出生成csv格式文件的方法
2018/01/11 Python
Python迭代器与生成器基本用法分析
2018/07/26 Python
django如何连接已存在数据的数据库
2018/08/14 Python
python flask框架实现传数据到js的方法分析
2019/06/11 Python
Python3 venv搭建轻量级虚拟环境的步骤(图文)
2019/08/09 Python
django中瀑布流写法实例代码
2019/10/14 Python
Python 3.8正式发布,来尝鲜这些新特性吧
2019/10/15 Python
Python读取excel文件中带公式的值的实现
2020/04/17 Python
简单了解python shutil模块原理及使用方法
2020/04/28 Python
中粮集团旗下食品网上购物网站:我买网
2016/09/22 全球购物
商场拾金不昧表扬信
2014/01/13 职场文书
小学节能减排倡议书
2014/05/15 职场文书
个人先进事迹材料
2014/12/29 职场文书
实习证明模板
2015/06/16 职场文书
幼儿园小班教师随笔
2015/08/14 职场文书