详解js的六大数据类型
发布时间 - 2026-01-10 22:08:24 点击率:次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中一些常见的数据类型检查校验
# 转换为
# 浮点数
# 的是
# 是一个
# 报错
# 也会
# 说到
# 这段
# 只有一个
# 结果是
# 面向对象
# 编程语言
# 如果你
# 是在
# 在这个
# 将会
# 浮点
# 两种
# 中有
# 适用于
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
iOS发送验证码倒计时应用
海南网站制作公司有哪些,海口网是哪家的?
Laravel如何创建自定义中间件?(Middleware代码示例)
高端企业智能建站程序:SEO优化与响应式模板定制开发
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
Laravel如何优化应用性能?(缓存和优化命令)
北京网站制作公司哪家好一点,北京租房网站有哪些?
Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
如何基于云服务器快速搭建网站及云盘系统?
如何快速搭建高效WAP手机网站吸引移动用户?
1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤
高防服务器如何保障网站安全无虞?
个人摄影网站制作流程,摄影爱好者都去什么网站?
Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践
如何制作一个表白网站视频,关于勇敢表白的小标题?
详解Android——蓝牙技术 带你实现终端间数据传输
如何在阿里云完成域名注册与建站?
如何用腾讯建站主机快速创建免费网站?
北京的网站制作公司有哪些,哪个视频网站最好?
EditPlus中的正则表达式 实战(2)
php增删改查怎么学_零基础入门php数据库操作必知基础【教程】
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
如何快速登录WAP自助建站平台?
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
如何快速启动建站代理加盟业务?
html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
免费网站制作appp,免费制作app哪个平台好?
Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南
详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点
如何在建站之星绑定自定义域名?
Laravel怎么实现支付功能_Laravel集成支付宝微信支付
C++时间戳转换成日期时间的步骤和示例代码
高端智能建站公司优选:品牌定制与SEO优化一站式服务
Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控
Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
Laravel如何实现API版本控制_Laravel版本化API设计方案
西安专业网站制作公司有哪些,陕西省建行官方网站?
如何快速打造个性化非模板自助建站?
如何在IIS服务器上快速部署高效网站?
网站制作软件免费下载安装,有哪些免费下载的软件网站?

