Javascript的5种基本数据类型总结

本文总结了JavaScript中的5种基本数据类型:Undefined, Null, Boolean, Number和String。讲解了typeof操作符的用法,以及各种类型的特点和转换方法,如Undefined的默认值,Null作为空对象引用,Boolean的true和false,Number的数值表示形式,以及String的不可变性等。" 133508312,20036098,使用jvisualvm监控Tomcat服务器详解,"['java', 'tomcat', '服务器监控']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ECMAScript中有5种基本数据类型,分别是:Undefined, Null, Boolean, Number和String,还有一种复杂数据类型Object,Object本质上是由一组无序的名值对组成的。(这里就不细细讲述了)

typeof操作符
typeof操作符是负责检测给定变量的数据类型,下面是几个使用typeof操作符的例子
在这里插入图片描述
这说明typeof操作符可以是变量,可以是数值字面量。注意,typeof是一个操作符而不是一个函数,因此例子中的圆括号尽管可以使用,但不是必须的。
调用typeof null会返回Object,因为特殊值null被认为是一个空的对象引用。

  1. Undefined类型

Undefined类型 只有一个值,即特殊的uhdefined. 在使用var 声明但未对其加以初始化时,这个变量的值就是undefined(默认获得的)

var message;
alert(message==undefined);  //true

但是,包含undefined值的变量与尚未定义的变量还是不一样的。

var message; //这个变量声明之后默认取得了undefined值
//var age;  //该变量未声明
 alert(message);  //undefined
 alert(age);  //报错
  1. Null类型
    Null类型是第二个只有一个值得数据类型,这个值就是null 。从逻辑角度看,null值便是一个空对象指针,所以在用typeof操作符检测时会返回object
var book=null;
alert(typeof book);  //object

注意,如果定义的变量准备在将来用于保存对象,那么最好将该变量初始化为null而不是其他值。这样的话,只要直接检查null值就可以知道相应的变量是否已经保存了一个对象的引用。

  1. Boolean类型
    Boolean类型只有两个字面值:true和false,这两个值是区分大小写的,也就是说,True和False都不是Boolean值,只是标识符。
    在ECMAScript中要将一个值转换为一个Boolean值,可以使用转型函数Boolean()
    在这里插入图片描述

  2. Number类型
    最基本的数值字面量格式是十进制整数,十进制整数可以向下面那样直接在代码中输入

var intNum=55;

除了十进制表示外,还可以通过八进制和十六进制来表示。其中,八进制字面值得第一位必须是0,然后是八进制数字序列(0~7)。如果后接的字面值超出范围,则前面的导零失效,后面的值将被当做十进制数值解析。

var a=065;  //八进制的53
var b=085;   //85
var c=08;  //8
alert(a);
alert(b);
alert(c);

八进制字面量在严格模式下是无效的,会导致支持该模式的JavaScript引擎抛出错误。
十六进制字面值的前两位必须是0x,后跟任何十六进制数字(0-9及A-F)。字母可以大小写。

var a=0xA;
var b=0x1f;
console.log(a);//十六进制的10
console.log(b);//十六进制31

在进行算术计算时,所有以八进制和十六进制表示的数值最终会被转换成十进制数值。

  • 浮点数值
    浮点数值就是指该数值中必须包含一个小数点,并且小数点后面必须至少有一位数字。虽然小数点前面可以没有整数但不推荐。
var floatNum1=1.2;
var floatNum2=0.2;
var floatNum3=.2;
console.log(floatNum1);//1.2
console.log(floatNum2);//0.2
console.log(floatNum3);//0.2 虽然小数点前面可以没有整数但不推荐

由于保存浮点数值需要的内存空间是保存整数数值的两倍,所以ES会将浮点数值转换为整数值。如果小数点后面没有跟任何数字,会解析成整数保存。如果浮点数值本身表示的就是一个整数,那么该数值就会被转换为整数。

var floatNum4=1.;
var floatNum5=10.0;
console.log(floatNum4);//小数点后没有数字解析为整数1
console.log(floatNum5);//10

可以用e表示法(科学计数法)表示浮点数值。e表示法指表示的数值等于e前面的数值乘以10的指数次幂。前面的数可以是整数也可以是浮点数,中间是一个大写或小写的字母e,后面是10的指数幂。

var floatNum6=3.1456e7;
console.log(floatNum6);//31456000
  • NaN
    NaN,即非数值(Not a Number)是一个特殊的值。在ES中,任何数值除以非数值会返回NaN。
    首先,任何涉及NaN的操作(NaN/10)都会返回NaN。其次,NaN与任何值都不相等,包括NaN本身。
console.log(NaN==NaN); //false

针对NaN的特点,ES定义了isNaN()函数。这个函数接收一个参数,该参数可以是任何类型,函数会确定这个参数是否“不是数值”。isNaN()在接收到一个值之后,会尝试将这个值转换为数值。某些不是数值的值会直接转换为数值(如字符串“10”或者Boolean值)。 任何不能被转换为数值的值都会导致这个函数返回true.

console.log(isNaN(NaN)); //true
console.log(isNaN(10));//false
console.log(isNaN("10"));//false
console.log(isNaN(""));//false
console.log(isNaN("febby"));//true
console.log(isNaN(true));//false
  • 数值转换
    有3个函数可以把非数值转换为数值:Number()、parseInt()、parseFloat()。第一个函数Number()可以用于任何数据类型,而另外两个函数则专门用于把字符串转换为数值。
console.log(Number("Hello Febby")); //NaN
console.log(Number("")); //0
console.log(Number("000032"));//32 前导的零被忽略
console.log(Number(true));//1

parseInt()函数会忽略字符串前面的空格,直至找到第一个非空格字符。用parseInt()转换空字符串会返回NaN(Number()对空字符返回0)。

 console.log(parseInt("1234Febby"));//1234
 console.log(parseInt(""));//NaN
 console.log(parseInt("0xf"));//15 (十六进制)
 console.log(parseInt(32.6));//32  小数点不是有效的数字字符
 console.log(parseInt("075"));//75 (ES5认为是十进制)
 console.log(parseInt("70"));//70
 console.log(parseInt("0xa"));//10 (十六进制)

可以为这个函数提供第二个参数:转换时使用的基数(即多少进制)。

console.log(parseInt("0xf",16));//15
console.log(parseInt("AF",16)); //175  如果指定了16作为第二个参数,字符串可以不带前面的"0x"
console.log(parseInt("AF"));//NaN

第二个参数表示按几进制进行解析成十进制的数

//第二个参数表示按几进制进行解析成十进制的数
console.log(parseInt("10",2));//2
console.log(parseInt("10",8));//8
console.log(parseInt("10",10));//10
console.log(parseInt("10",16));//16

parseFloat()与parseInt()类似,从第一个字符(位置0)开始解析每个字符,但是只解析十进制值,没有用第二个参数指定基数的用法

//parseFloat()只解析十进制值,没有用第二个参数指定基数的用法
console.log(parseFloat("1234Febby"));//1234     
console.log(parseFloat("0xa")); //0  十六进制格式的字符串会被转换为0
console.log(parseFloat("071")); //71
console.log(parseFloat("22.5"));  //22.5     
console.log(parseFloat("22.34.56")); //22.34
console.log(parseFloat("0958.2")); //958.2
console.log(parseFloat("3.145e7")); //31450000
  1. String类型
    String类型用于表示由零或多个16位Unicode字符组成的字符序列,即字符串。字符串可以有双引号或单引号表示。
console.log("Febby");
console.log('Febby');
console.log('Febby"); //报错
  • 字符字面量(转义序列)
字面量含义
\n换行
\t制表
\b退格
\r回车
\f进纸
\ \斜杠
\ ’单引号(’)
\ "双引号(”)
\xnn以十六进制代码nn表示的一个字符(其中n为0~F)。例如,\x41表示"A"
\unnn以十六进制代码nnnn表示的一个字符(其中n为0~F)。例如,\u03a3表示"Σ"
var text="Hello Febby! \u03a3";
console.log(text); //Hello Febby! Σ
console.log(text.length);//14
  • 字符串特点
    ES中的字符串是不可变的。要改变某个变量保存的字符串,首先要销毁原来的字符串,然后再用另一个包含新值的字符串填充该变量,这个过程是在后台发生的。
 var lang="Hello";
 lang=lang+"Febby";
 console.log(lang);//HelloFebby
  • 转换为字符串
    要把一个值转换为字符串有两种方式。
    第一种是 toString()方法。这个方法是返回相应的值的字符串表现。
 //转换为字符串
 var age=18;
 console.log(age.toString()); //字符串"18"

数值、布尔值、对象和字符串值都有toString()方法,但null和undefined值没有这个方法。

可以传递一个参数:输出数值的基数,可以输出以二进制、八进制、十六进制,或者其他进制格式表示的字符串值

 //可以传递一个参数:输出数值的基数,可以输出以二进制、八进制、十六进制,或者其他进制格式表示的字符串值
 var num=10;
 console.log(num.toString());//"10"
 console.log(num.toString(2));//"1010"
 console.log(num.toString(8));//"12"
 console.log(num.toString(10));//"10" 
 console.log(num.toString(16));//"a"

第二种是 String()方法。这个函数能够将任何类型的值转为为字符串。因为null和undefined值没有toString()方法,所以String()函数就返回了这两个值的字面量。

console.log(String(10)); //"10"
console.log(String(true));//"true"
console.log(String(null));//"null"
console.log(String(""));//
console.log(String(undefined)); //"undefined"

以上就是javascript的5种基本数据类型总结,希望可以帮到大家!!

知识来源:《Javascript高级程序设计》
String类型分篇传送门: https://blog.youkuaiyun.com/Febby_/article/details/90119263
Number类型分篇传送门:https://blog.youkuaiyun.com/Febby_/article/details/90119879

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值