JS的数据类型

文章介绍了JavaScript中的数据类型,包括数字、字符串、对象和undefined,强调了类型检测和数字的表示方法,如进制转换、科学计数法和数值范围。还讨论了字符串的使用,如引号问题和字符串拼接,并提到了对象类型的表示形式。
摘要由CSDN通过智能技术生成

私人博客

许小墨のBlog —— 菜鸡博客直通车

系列文章完整版,配图更多,CSDN博文图片需要手动上传,因此文章配图较少,看不懂的可以去菜鸡博客参考一下配图!

系列文章目录

前端系列文章——传送门
JavaScript系列文章——传送门



1、前言

思考:如何输出一句话?

// 在页面上显示:你好,世界!
document.write(123456)
document.write(你好,世界!)

此时浏览器会报错:

你好,世界! is not defined

这个报错表达的意思是说,将“你好,世界!”识别为了一个变量,但是这个变量没有定义过。

也就是说变量在定义的时候,变量的名字还可以使用中文:

var= 123;
console.log();

这样也是可以的,但是建议不要使用中文汉字作为变量名。

那怎样才能输出上面的中文汉字一段话呢?我们需要给这段话加引号:

console.log("你好,世界!");

从上面的示例中,可以看到,输出数字不需要加引号,但是输出一段话就需要加引号,也就是说,数据有时候不需要加引号,但有时候就需要加引号,这是因为数据的类型不一致造成的。

js中可以输出数字,输出一段带引号的话,还可以输出哪些数据?

数字、带引号的数据、没有赋值的变量、true、false、[]数据、{}数据、null

根据他们的用途和特性,可以将数据分为以下几类:

类型示例备注
数字型(number)1 -2 3.14 300包括整数、小数、负数
字符串型(string)“你好吗?” ‘今天嫁给我’用引号引起来的任意多任意字符,单引号和双引号都行
布尔型(boolean)true false代表事物的两面性,真和假
未定义型(undefined)var a代表定义过未赋值的变量
对象(object)null [1,2,3] {name:张三}代表一个集合

2、类型检测

使用typeof(被检测的内容)可以得出一个内容的类型。

console.log(typeof(-123456)); // 数字型
console.log(typeof("明天会更好")); // 字符串型
console.log(typeof(true)); // 布尔型
console.log(typeof(x)); // 布尔型
console.log(typeof([1,2,3])); // 对象
console.log(typeof({name:"张三",age:12})); // 对象
console.log(typeof(null)); // 对象

多学一招:typeof(x) 可以写成 typeof x 。使用小括号和空格都可以。

3、数字类型

在结果中可以看到使用number来代表数字类型。

3.1、了解内容

3.1.1、不同进制的数字

我们一般使用使用的数字是十进制的,但是在js中我们还可以使用八进制和十六进制。

var a = 010; // 8进制
var b = 0xA; // 16进制
var c = 0xb; // 小写字母和大写字母都可以
console.log(a); // 8
console.log(b); // 10
console.log(c); // 11

3.1.2、科学计数法

数字的表达当中,有一种叫科学记数法,js中的数字也可以使用科学记数法来表示

//当一次数字很大的时候,可以用科学计数法来表示
var num = 3e+5;  //3乘以10的5次方
var num = 5e-3;//5乘以10的-3次方

3.1.3、数值范围

内存大和小有什么区别呢?存储的数据多和少的区别。那计算机存储数据是没有限制的吗?不是,计算机能表达的数字也有极限值:

最小值:Number.MIN_VALUE,这个值为: 5e-324
最大值:Number.MAX_VALUE,这个值为: 1.7976931348623157e+308
无穷大:Infinity    1/0
无穷小:-Infinity

3.2、重点内容

3.2.1、NaN

var a = "abc";
var b = 2;
var c = a - b;
console.log(c); // NaN

NaN: not a number, 表示一个非数字

在js中,NaN用来表示一个非数字的特殊值,当发现无法进行运算时,js不会报错,而是会返回一个NaN

NaN的注意事项:

  • NaN的类型是number类型的,表示一个非数字
  • NaN不等于任何值,包括NaN本身
  • 通过isNaN()可以判断是否是一个数字,返回false的时候,表示是一个数字。
var a = 123;
var b = "abc";
console.log(isNaN(a)); // false
console.log(isNaN(b)); // true

3.2.2、小数

计算机中的小数在进行运算的时候,有时会碰到小数点精度不准确的现象

//在进行浮点数运算的时候,可能会出现精度丢失的问题
0.1 + 0.2 = 0.30000000000000004;
0.2 + 0.2 = 0.4;

原因:

计算机内部所能识别的数据只有二进制,当我们进行10进制数字运算的时候,在计算机内部需要先将数据转为2进制,然后运算,再将结果转为10进制给出来。10进制的小数进行2进制转换的时候,根据转换规则,有些小数会进行无限死循环,最终在后面数字太多的时候只能四舍五入,所以其实最终并没有很精确的转为2进制,所以只能给出一个大概的值。有时候会有两个大概的值相加,在转换10进制的时候正好能转换了,也会计算的比较精准。

consoloe.log(0.2 + 0.2) // 0.4

也不绝对,如果小数是2的n次方分支m的话,计算机内部存储的就比较准确。

console.log(0.125 + 0.5) // 0.625

解决办法:

// 解决办法 : 
// 1.根据小数点后面的位数量 乘以对应的整数;
0.1 + 0.2  ==> (0.1*10+0.2*10) / 10 = 0.3
// 2.使用toFixed工具强制保留小数点后位数
var a = 0.1 + 0.2
console.log(a.toFixed(3)) // 0.300

4、字符串类型

字符串所使用的引号,在js中,单引号和双引号是没有区别的,使用哪个都一样。

字符串中的字符是任意字符,即只要在键盘上能输入的字符都是可以的。

单引号和双引号也是字符串的字符:

var str = '"' // 一个双引号字符的字符串
var str1 = "'" // 一个单引号字符的字符串

4.1、引号问题

但是双引号中不能包含双引号,单引号中不能包含双引号,因为引号对于字符串来讲是有特殊含义的,就是给字符串做边界,双引号定义的字符串,在字符串中碰到第一个双引号,就认为将前面的双引号结束了,单引号同理。

但在某些特殊情况下,双引号就需要嵌套双引号,单引号就需要嵌套单引号:

var str = '我说对妈妈说:"我学会了第一个代码'hello world'"';
console.log(str)

这个字符串在输出的时候是会报错的,因为,浏览器是这样解析这个字符串:

'我说对妈妈说:"我学会了第一个代码'   hello world   '"';

中间的汉字和两边的字符串之间并没有拼接,不符合js的语法,所以报错。

此时,关键的原因就是单引号字符串中碰到了第一个单引号,就将前面的单引号结束了,因为引号对于字符串是有特殊含义的。

解决方案:

给字符串中的引号转义,也就是将引号对于字符串的特殊含义去掉,就剩下普通字符的含义即可。转义是给引号前加反引号\

var str = '我说对妈妈说:"我学会了第一个代码\'hello world\'"';
console.log(str)

4.2、js输出标签

js可以输出标签,让页面中的元素具备标签的特性,但是在输出标签的时候一定要将标签当做字符串输出。

document.write('<b>你好,世界!</b>')

输出标签可以看出,每次输出,其实就是在body内容原本的基础上直接追加了,也就是说,一个标签可以分多次输出,结果和输出一次是一样的。

4.3、字符串的拼接

用变量代替每一次的输出:

var a = '<i>';
var b = '文字倾斜';
var c = '</i>';
document.write(a)
document.write(b)
document.write(c)

如果我们在此时希望能一次输出的话,就需要将多个变量连接在一起,组成一个更大的字符串才行,字符串之间的连接使用拼接符:+

var a = '<i>';
var b = '文字倾斜';
var c = '</i>';
document.write(a + b + c)

也就是说,字符串和字符串之间的 + 是可以将两个字符串连接在一起组成大字符串的。

5、对象类型

object类型,在js中有3种表现形式,分别是:

  • null
  • 用[]定义的数据
  • 用{}定义的数据

6、undefined类型

当一个变量定义好了,但是没有给这个变量赋值,也就是没有给这个容器中放入数据,这个变量的默认值就是undefined,类型也是undefined。


本博文缺失大量图片,严重影响内容完整性以及阅读体验,完整内容请前往本人菜鸡博客——许小墨のBlog

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
JavaScript数据类型包括字符串(String)、数字(Number)、布尔(Boolean)、对象(Object)、数组(Array)、空值(Undefined)和空引用(Null)等。\[1\]在JavaScript中,字符串是由一系列字符组成的,可以使用单引号或双引号表示。对象是一种复合数据类型,可以包含多个键值对。数组是一种特殊的对象,它以数字作为索引,存储多个值。数字可以是整数或浮点数,布尔值只有两个取值,即true和false。空值表示变量没有被赋值,而空引用表示变量的值为null,表示空对象。\[2\]在JavaScript中,可以通过typeof运算符来检测数据类型。此外,还可以通过拼接空字符串、使用toString()方法或拼接带参数的字符串来将数值型转化为字符串型。\[3\] #### 引用[.reference_title] - *1* [JavaScript数据类型](https://blog.csdn.net/huishi__/article/details/123454041)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [JavaScript 学习手册二:JS 数据类型](https://blog.csdn.net/weixin_54327001/article/details/121964883)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [JavaScript的七种数据类型](https://blog.csdn.net/Zhang_wang_yun/article/details/129959316)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

许小墨~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值