全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解js的六大数据类型

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

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


# js  # 数据类型  # js判断数据类型如判断是否为数组是否为字符串等等  # javascript中的五种基本数据类型  # js 判断数据类型的几种方法  # js 数据类型转换总结笔记  # js 判断各种数据类型的简单方法(推荐)  # Javascript如何判断数据类型和数组类型  # JavaScript中数据类型转换总结  # js的各种数据类型判断的介绍  # javaScript中一些常见的数据类型检查校验  # 转换为  # 浮点数  # 的是  # 是一个  # 报错  # 也会  # 说到  # 这段  # 只有一个  # 结果是  # 面向对象  # 编程语言  # 如果你  # 是在  # 在这个  # 将会  # 浮点  # 两种  # 中有  # 适用于 


相关文章: 建站之星2.7模板:企业网站建设与h5定制设计专题  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  如何通过西部数码建站助手快速创建专业网站?  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  如何用PHP工具快速搭建高效网站?  如何通过万网虚拟主机快速搭建网站?  ,怎么在广州志愿者网站注册?  如何在IIS中新建站点并解决端口绑定冲突?  建站主机如何选?高性价比方案全解析  如何设置并定期更换建站之星安全管理员密码?  如何用AWS免费套餐快速搭建高效网站?  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  建站之星后台密码遗忘如何找回?  详解jQuery停止动画——stop()方法的使用  家具网站制作软件,家具厂怎么跑业务?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  做企业网站制作流程,企业网站制作基本流程有哪些?  如何在西部数码注册域名并快速搭建网站?  如何配置WinSCP新建站点的密钥验证步骤?  江苏网站制作公司有哪些,江苏书法考级官方网站?  Android自定义控件实现温度旋转按钮效果  网站好制作吗知乎,网站开发好学吗?有什么技巧?  如何彻底删除建站之星生成的Banner?  Python文件管理规范_工程实践说明【指导】  建站之星后台密码遗忘或太弱?如何重置与强化?  高防服务器租用首荐平台,企业级优惠套餐快速部署  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  香港服务器部署网站为何提示未备案?  官网建站费用明细查询_企业建站套餐价格及收费标准指南  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  如何通过WDCP绑定主域名及创建子域名站点?  网站制作的方法有哪些,如何将自己制作的网站发布到网上?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  建站之星免费模板:自助建站系统与智能响应式一键生成  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  电商网站制作价格怎么算,网上拍卖流程以及规则?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何自定义建站之星网站的导航菜单样式?  如何用花生壳三步快速搭建专属网站?  如何通过建站之星自助学习解决操作问题?  相册网站制作软件,图片上的网址怎么复制?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  如何在云虚拟主机上快速搭建个人网站?  网站制作公司排行榜,抖音怎样做个人官方网站 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。