JavaScript -- 02. 变量和数据类型

news2025/1/16 14:08:26

文章目录

  • 变量和数据类型
    • 1 数值(Number)
      • 1.1 普通数值
      • 1.2 其他进制的数字
    • 2 大整数(BigInt)
    • 3 字符串(String)
      • 3.1 基础表示
      • 3.2 转义字符
      • 3.3 模板字符串
    • 4 布尔值(Boolean)
    • 5 空值(Null)
    • 6 未定义(Undefined)
    • 7 符号(Symbol)
    • 8 类型转换
      • 8.1 转换为字符串
      • 8.2 转换为数值
      • 8.3 转换为布尔值
      • 8.4 总结

变量和数据类型

JS中的变量和数据类型:字面量和变量的介绍、变量的声明方式(let、var)、常量(const)、原始值(String、Number、BigInt、Boolean、Null、Undefined、Symbol)、值和变量在内存中的结构、不可变类型、显式类型转换等内容

数据类型,指那些可以赋值给变量的值,JS中的数据类型由原始值和对象共同组成。

JavaScript中一共有七种原始值,原始值在JS中是不可变类型,一旦创建就不能修改:

在修改变量的值的时候没办法直接改掉这个这个值,只能是创建一个新值,让变量指向新值

  • 数值(Number)
  • 大整数(Biglnt)
  • 字符串(String)
  • 布尔值(Boolean)
  • 空值(NuIl)
  • 未定义(Undefined)
  • 符号(Symbol)

类型检查:typeof

  • typeof用来检查不同的值的类型
  • 它会根据不同的值返回不同的结果
  • 返回结果是一个字符串,字符串描述了该变量的类型
  • 要区分变量和值的概念,js中变量是没有类型的,只有值有类型,typeof检查的是值的类型,变量只是指向值的一个引用

image-20221130001039244

1 数值(Number)

1.1 普通数值

  • 在JS中所有的整数和浮点数都是Number类型

  • JS中的数值并不是无限大的,当数值超过一定范围后会显示近似值

    image-20221129235820220

  • 当数值很小的时候,也会显示近似值

    image-20221130000029145

  • Infinity 是一个特殊的数值表示无穷

  • 所以在JS中进行一些精度比较高的运算时要十分注意

    image-20221130000052939

  • NaN(Not a Number) 也是一个特殊的数值,表示非法的数值

NaN是js中的一个特殊的东西,在其他语言中一般都会直接报错

image-20221130000217046

1.2 其他进制的数字

  • 二进制:0b
  • 八进制:0o
  • 十六进制:0x

不管什么进制的数字,在打印的时候都会显示成10进制

image-20221130000727910

2 大整数(BigInt)

  • 大整数用来表示一些比较大的整数
  • 大整数使用n结尾,它可以表示的数字范围是无限大
  • 只能表示整数,不能表示小数

只要内存不溢出就可以表示

大整数只能和大整数计算,不能和基础数值混合计算

image-20221130000438136

3 字符串(String)

3.1 基础表示

在JS中使用单引号或者双引号来表示字符串(不能混着用)

let a = "Hello"
a = "你好"

3.2 转义字符

在JS中很多符号都是有特殊含义的,比如单引号和双引号,被用来标识字符串,如果想要在字符串中出现的话会导致一些问题,所以这个时候需要转义字符

比如:

// 使用 let a = "123"123123" 会报错,正确的用法是
let a = "123\"123"

常见的转移字符如下:

转义字符意义ASCII码值(十进制)
\b退格(BS) ,将当前位置移到前一列008
\n换行(LF) ,将当前位置移到下一行开头010
\r回车(CR) ,将当前位置移到本行开头013
\t水平制表(HT) (跳到下一个TAB位置)009
\\代表一个反斜线字符’‘’092
\’代表一个单引号(撇号)字符039
\"代表一个双引号字符034
?代表一个问号063

3.3 模板字符串

在JS中,通过单引号和双引号引起来的字符串是不能换行的,如果要换行的话可以使用\

let a = "aaa\
		bbb"

image-20221130002141352

但是使用很不方便,在JS中引入了一种叫做模板字符串的东西,使用方式是通过反引号括起来

let a = `123
		2312`

image-20221130002130706

对比发现,在模板字符串中,多了一个\n,说明其可以将换行的信息也保存下来

除此之外,模板字符串最大特点是可以嵌入变量

let name = "张三"
let str = `你好,${name}`
console.log(str)

image-20221130002326102

4 布尔值(Boolean)

布尔值(Boolean)

  • 布尔值主要用来进行逻辑判断
  • 布尔值只有两个true 和 false
  • 使用typeof检查一个布尔值时会返回 “boolean”
let a = true 	// 真
let b = false	// 假

image-20221130002834355

5 空值(Null)

空值 (Null)

  • 空值用来表示空对象
  • 空值只有一个 null
  • 使用typeof检查一个空值时会返回"object"
  • 使用typeof无法检查空值

image-20221130002900189

6 未定义(Undefined)

未定义(Undefined)

  • 当声明一个变量而没有赋值时,它的值就是Undefined
  • Undefined类型的值只有一个就是 undefined
  • 使用typeof检查一个Undefined类型的值时,会返回 “undefined”

image-20221130002946295

7 符号(Symbol)

符号(Symbol)

  • 用来创建一个唯一的标识
  • 使用typeof检查符号时会返回 “symbol”
let c = Symbol() // 调用Symbol()创建了一个符号
console.log(typeof c)

image-20221130003305498

8 类型转换

类型转换指将一种数据类型转换为其他类型

类型转换是根据当前值去创建另一个值,而不是将当前值直接进行转换

这里说到的转换都是显示类型转换,除此之外还有隐式类型转换

8.1 转换为字符串

  1. 调用toString()将其他类型转换为字符串

    由于null和undefined中没有toString()方法,所以对这两个函数调用toString()的时候会报错

    image-20221130103929105

调用String()函数

  • 对于拥有toString()的值调用String()函数时,实际上就是在调用toString()方法
  • 对于null,则直接转换为"null"
  • 对于undefined,则直接转换为"undefined"

image-20221130104240420

8.2 转换为数值

使用Number()函数将其他数值转换为数值

image-20221130105056482

转换情况:

  • 字符串:
    • 如果字符串是一个合法的数字,则会自动转换为对应的数字
    • 如果字符串不是合法数字,则测转换为NaN
    • 如果字符串是空串或纯空格的字符串,则转换为0
  • 布尔值:
    • true转换为 1,false转换为 0
  • null 转换为 0
  • undefined 转换为 NaN

专门用来将字符串转换为数值的两个方法

这两个函数接受的参数都是string,如果传入的参数不是字符串的话,会自动转换为string

  • parseInt():将一个字符串转换为一个整数
    • 解析时候,会自左向右读取一个字符串,直到读取到字符串中所有的有效的整数
    • 也可以使用parseInt()来对一个数字进行取整
  • parseFloat():将一个字符串转换为一个浮点数
    • 解析时候,会自左向右读取一个字符串,直到读取到字符串中所有的有效的小数
let a = "123px"
console.log(typeof a, a) // string 123px

let b = parseInt(a)
console.log(typeof b, b) // number 123

let c = parseInt("a123")
console.log(typeof c, c) // number NaN

let d = parseInt(123.456)
console.log(typeof d, d) // number 123

8.3 转换为布尔值

使用Boolean()函数将其他类型转换为布尔值

记false的情况就好了,false的情况比较少,其余的情况都是true

  • 转换的情况:

    • 数字:

      • 0 和 NaN 转换为false
      • 其余是true
    • 字符串:

      • 空串 转换为 false
      • 其余是true
    • null和undefined 都转换为 false

    • 对象:对象会转换为true

  • 所有表示空性的没有的错误的值都会转换为false:

    • 0、NaN、空串、null、undefined、false
Boolean(1) // true
Boolean(-1) // true
Boolean(0) // false
Boolean(NaN) // false
Boolean(Infinity)) // true

Boolean('abc') // true
Boolean('true') // true
Boolean('false') // true
Boolean('') // false
Boolean(" ") // true
Boolean(null) // false
Boolean(undefined) // false

8.4 总结

隐式转换在运算符讲解

  • 转换为字符串
    • 显式转换:String(a)
    • 隐式转换: a + ""
  • 转换为数值
    • 显式转换:Number(a)
    • 隐式转换:+a
  • 转换为布尔值
    • 显式转换:Boolean(a)
    • 隐式转换:!!a

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/49371.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

6-2 装载问题(分支限界)

6-2 装载问题(分支限界) 一、问题描述 有一批共个集装箱要装上2艘载重量分别为C1和C2的轮船,其中集装箱i的重量为Wi,且 采用下面的策略可得到最优装载方案: (1)将第一艘轮船尽可能装满; (2)将剩余集装箱装上第二艘轮…

基于rsync daemon 实现 sersync——sersync实现实时数据同步

1 sersync 介绍 sersync类似于inotify,同样用于监控,但它克服了inotify的缺点. inotify最大的不足是会产生重复事件,或者同一个目录下多个文件的操作会产生多个事件,例如,当监控目录中有5个文件时,删除目录…

[附源码]计算机毕业设计springboot考试系统

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

学习C语言的优质网站

1. 初衷 C语言是最原始的操作操作数据结构和算法的一门编程语言,没有高级语言的封装,最能锻炼个人的算法思维和能力。 2. 编程网站推荐 2.1 javatpoint https://www.javatpoint.com/static-in-c 2.2 includehelp https://www.includehelp.com/c/ 2.…

Hadoop学习笔记——HDFS

文章目录一、HDFS概述1.1、HDFS产出背景及定义1.1.1 HDFS产生背景1.1.2 HDFS定义1.2、HDFS优缺点1.2.1、HDFS优点1.2.2、HDFS缺点1.3、HDFS组成架构1.4、HDFS文件块大小1.5、限制二、HDFS的Shell操作2.1、基本语法2.2、命令大全2.3、常用命令实操2.3.1 准备工作2.3.2 上传一、H…

快速复现 实现 facenet-retinaface-pytorch 人脸识别 windows上 使用cpu实现

目录0 前言1 搭建环境与项目2 人脸预测与结果展示0 前言 这一次要复现的是人脸识别中的 facenet-retinaface-pytorch 是在上一次博客的内容上更进一步 快速复现 实现 facenet-pytorch 人脸识别 windows上 使用cpu实现 人脸对比 参考了: Pytorch 利用Facenet和Reti…

10 Deployment:让应用永不宕机

文章目录1. 前言2. 为什么要有deployment 对象?3. 如何使用 YAML 描述 Deployment?3.1 查看 Deployment 的基本信息3.2 命令式创建Deployment 的YAML模板3.2.1 Deployment 的关键字段3.2.1.1 replicas 副本字段3.2.1.2 selector 标签筛选字段3.2.1.3 为什么在 YAML…

JAVA学习-java基础讲义02

java基础讲义02一 进制1.1 进制介绍1.2 二进制1.3 任意进制到十进制转换1.4 十进制到任意进制之间的转换1.5 快速转换法1.6 有符号数据表示法二 Java变量和数据类型1.1 变量概述1.2 数据类型1.3 变量定义三 Java数据类型转换3.1 数据类型转换概述3.2 数据类型转换之自动类型转换…

使用自己的数据集测试Unbiased Mean Teacher for Cross-domain Object Detection

要复现Unbiased Mean Teacher for Cross-domain Object Detection(UMT),首先要正确运行CycleGAN。 1. CycleGAN CycleGAN的github链接:https://github.com/junyanz/pytorch-CycleGAN-and-pix2pix 1.1 CycleGAN环境配置 git cl…

低代码助力生产管理:车间管理系统

在当前制造业全球化、网络化、敏捷化的背景下,制造业信息化是目前生产的主要趋势。其中车间是制造企业的核心单元,是企业生产计划的具体实施环节,同时负责反馈实时生产信息。因此车间层的信息资源集成和生产管理控制是整个企业生产供应链控制…

[Power Query] 快速计算列

对两列或者多列的计算,在Power Query中除了通过自定义列来实现以外,我们也可以通过利用功能区的【添加列】|【标准】运算功能进行列的计算 数据源 将数据源导入到Power BI Desktop,单击【转换数据】选项,进入Power Query查询编辑…

python对异常的处理

了解异常当检测到一个错误时,解释器就无法继续执行了,反而出现一些错误的提示,这就是异常。测试:f open(test.txt,r) #以读模式打开文件,文件不存在则报错 运行了解释器报错避免出现异常提示的写法 #需求:…

串口通信及串口转蓝牙相关知识

之前没有接触过硬件相关的工作, 因此对硬件的知识一知半解。 最近由于项目需要, 用到了串口通信以及串口跟蓝牙之间通信相关的东西。记录下来, 希望对新手有所帮助。 如有疏漏之处, 欢迎指正。 1 串口通信 https://www.jishulin…

docker-compose安装部署gitlab中文版

文章目录前言一、环境信息二、准备部署1.准备路径2.安装docker-compse,下载镜像3.引入库2.执行部署三、登陆页面前言 记录一下使用docker-compose部署gitlab平台的过程 一、环境信息 操作系统版本:CentOS Linux release 7.9.2009 (Core) gitlab镜像版本…

世界杯winner只属于你——MESSI

其实现在大脑中还在回忆着那一脚精彩的进球。 看官方怎么说的: 北京时间11月27日凌晨3点,世界杯C组第2轮,阿根廷2-0战胜墨西哥。 梅西在11月27日用1进球1助攻,上帝降临,拯救阿根廷。特别是那个进球,直接让…

矩阵快速幂 笔记加理解

文章目录1.何为快速幂1.1学习快速幂的好文章1.2快速幂取模代码(对1000取模)2.矩阵快速幂1.何为快速幂 补充一个公式证明: 1.1学习快速幂的好文章 http://t.csdn.cn/agKop 1.2快速幂取模代码(对1000取模) ll fast…

VMware虚拟网络编辑器配置

一,NAT模式网络设置。 把下面的ip,子网掩码,网关记住。 切换到network-scripts 目录下。 cd /etc/sysconfig/network-scripts/修改ifcfg-ens33 这个文件。 然后重启网络服务: 对于openEuler: systemctl restart Ne…

关于Eslint语法检查

在vue创建项目中,选择eslintStandard config -标准规范- 在保存时就开启检查 eslintrc.js配置,没反应重启项目 语法报错,根据错误提示,去eslint官网搜索规则 在eslintrc.js文件中rules中添加或者修改规则,自定义的…

猿如意|IntelliJ IDEA Community下载安装以及基础开发设置和快捷键设置的详细教程

文章目录 一、如何在猿如意官网中下载IntelliJ IDEA Community? 二、关于IntelliJ IDEA Community的安装以及使用前的设置教程 1.下载安装 2.基础开发设置 三、总结 一、如何在猿如意官网中下载IntelliJ IDEA Community? 我们要想能够更简单的获取到Int…

【愚公系列】华为云系列之DevCloud+ECS+MySQL搭建超级冷笑话网站【开发者专属集市】

文章目录前言1.项目背景2.项目介绍3.所需华为云环境一、华为云系列之DevCloudECSMySQL搭建超级冷笑话网站1.创建项目2.创建代码仓库3.创建数据库4.修改代码5.编译构建6.部署7.环境准备8.导入主机9.部署应用10.应用访问11.资源释放11.1 释放 ECS 资源11.2 释放 RDS 资源总结前言…