A. js高级(三)----可选链 && Map && Set
可选链(?.) 是一种简化代码的语法,它允许在访问嵌套对象属性时,检查对象是否为 null 或 undefined。通过使用可选链,代码变得更加简洁易读,减少了长串的逻辑判断。例如:
原本可能需要使用大量的逻辑判断,现在只需一行可选链语法即可实现相同功能。可选链简化了代码,避免了冗长的表达,提高了代码的可读性。
总结了之前关于 JS 高级的主题,检查变量是否为 null 或 undefined 的方法有三种:
短路 (&& 和 ||):这种方法在逻辑判断上有一定的缺陷,因为它会进行隐式转换,如0和""会被转换为false。
空合并(??):此方法提供了一种更加精准的检查方式,只会检查变量是否为 null 或 undefined,并不会进行隐式转换。
可选链(?.):这种语法在检查变量是否存在时,只检查是否为 null 或 undefined,并且以简洁的语法实现,使得代码更加易于理解和阅读。
Map 是一种与对象类似的集合数据结构,但具有不同的特性。以下是 Map 的基本语法和使用方法:
实例化 Map:可以使用以下方式创建 Map 对象,然后对其进行操作。
Map 操作方法:包括读取数据(get(key))、新增数据(set(key, value))、检查键是否存在(has(key))、删除数据(delete(key))和清空数据(clear())。
与对象相比,Map 在数据结构和操作方法上具有明显区别,如键值对的唯一性、使用场景和操作方式。
Set 是一种类似于数组的数据结构,但其特性在于元素的唯一性。这意味着集合中不会有重复的数据。以下是 Set 的基本语法和特性:
数据唯一性:Set 集合中的元素只会出现一次,重复的数据不会被添加。
Set API:Set 提供了三个主要方法,用于检查值是否存在(has(value))、添加值(add(value))和删除值(delete(value))。
通过这些方法,Set 实现了数据的唯一性和高效管理,使得在处理集合数据时更加灵活和方便。
B. js两种数据类型(javascript中的数据类型分为两大类)
JS的基本数据类型JS中一共有六种基本数据类型,分别是Undefined、Null、Boolean、Number、String,还有在ES6中新增的Symbol和ES10中新增的BigInt类型。
1.Undefined:未定义型??
一个变量声明了但是未赋值的情况下就是undefined;
2.Null:空型
一般用来清空变量,也起了占位作用
3.String:字符型
凡是被双引号或单引号包裹起来的都叫做字符型,字符串有length属性。
4.Number:数值型
包含整数和浮点数(浮点数数值必须包含一个小数点,且小数点后面至少有一位数字)两种值。
(1)NaN:非数字类型。
特点:①涉及到的任何关于NaN的操作,都会返回NaN???
??????②NaN不等于自身。
(2)isNaN():用于检查其参数是不是数值,得到的结果是一个布尔值,不是数值返回true,是数值返回false。
5.Boolean:布尔型
只有true和false两个值。
6.Symbol代表创建后独一无二且不可变的数据类型,它的出现我认为主要是为了解决可能出现的全局变量冲突的问题。
7.BigInt是一种数字类型的数据,它可以表示任意精度格式的整数,使用BigInt可以安全地存储和操作大整数,即使这个数已经超出了Number能够表示的安全整数范围。
JS数据类型(七种基础,三种引用)
在JS的学习与工作中,搞清楚相关数据类型是基础中的基础,平均一百家公司面试前端工程师的时候九十九家都会问,请你简单举例一下JS的数据类型,于是菜狗我就将对此进行一些自己粗浅的总结为自己留作笔记同时为各位想要学习的同学提供小小的帮助。
首先,我们要明白,在JS中,数据类型分为一下两种:
基础数据类型分为七种
①Number数字型(包含所有的整数,浮点数,负数等)
②String字符串型(包含任意文本)
③boolean布尔型(仅有两种类型,ture与false)
④Undefined未定义(仅有一种,undefined)
⑤Null空/不存在(仅有一种,null)
⑥Symbol(实现唯一标识)
对此进行简单的举例
⑦BigInt(任意精度整数)(将与ES10中出现)
对此数据类型存在进行简单解释
BigInt通过数字加n的方法来表示,支持二进制,八进制,十六进制
以下写法结果均为转换为字符串后得而结果,BigInt类型转换字符串后不会再带着n
Ⅰ.通常写法
Ⅱ.十六进制
Ⅲ.八进制(注意区分数字0与字母o)
Ⅳ.二进制
引用数据类型共有三种
①Array类型(数组型)
②Object类型(对象型)
③Function类型(函数/方法)
以上就是十种JS中的数据类型,如有错误,欢迎指正。
如果本文能帮到你,那么菜狗很开心,大家一起加油!
js数据类型js中有六种数据类型,包括五种基本数据类型(Number,String,Boolean,Undefined,Null),和一种复杂数据类型(Object)。
1、Number类型
Number类型包含整数和浮点数(浮点数数值必须包含一个小数点,且小数点后面至少有一位数字)两种值。
2、String类型
在JS中字符串需要使用引号引起来。使用双引号或单引号都行,但是不要混着用。引号不能嵌套,双引号不能放双引号,单引号不能放单引号。
3、Boolean类型
该类型只有两个值,true和false。
4、Undefined类型
只有一个值,即undefined值。使用var声明了变量,但未给变量初始化值,那么这个变量的值就是undefined。
5、Null类型
null类型被看做空对象指针,null类型也是空的对象引用。
6、Object类型
js中对象是一组属性与方法的集合。这里就要说到引用类型了,引用类型是一种数据结构,用于将数据和功能组织在一起。引用类型有时候也被称为对象定义,因为它们描述的是一类对象所具有的属性和方法。
js基本数据类型有哪些js的基本数据类型有6种:Number,String,Boolean,Object,Null,Undefined。
数据类型的种类js一共有六种数据类型其中有五种简单数据类型包括:String、Number、Boolean、undefined、Null2.数据类型的检测可以使用typeof来检测数据类型。
js的数据类型有哪些JS数据类型有7种,分别是:3种基本类型(数字,字符串,布尔),2种引用数据类型(对象,数组),以及2种特殊数据类型(undefined,null)。
JavaScript(简称“JS”)是一种具有函数优先的轻量级,解释型或即时编译型的高级编程语言。虽然它是作为开发Web页面的脚本语言而出名的,但是它也被用到了很多非浏览器环境中,JavaScript基于原型编程、多范式的动态脚本语言,并且支持面向对象、命令式和声明式(如函数式编程)风格。
Javascript中一切皆为对象。然后引用类型其实指的是内存中存储的是值的一个地址,而不是这个值的本身。和它相对应的是值类型,值类型在内存中是直接存储值本身的。比如一段字符串。
当修改一个引用类型obj1上的str的值时,因为obj2和obj1引用的是同一地址,所以obj2的str也会跟着改变,当我直接把另一个新的值赋给obj1时,这时obj1和obj2的引用地址不一样了,所以obj2的str不再跟着改变,而值类型不会有这类问题。
C. 使用JS生成UUID的常用方法
UUID 是一种通用唯一识别码,用于在分布式计算环境中提供独一无二的标识。在JavaScript中生成UUID的方法主要有三种,下面将逐一介绍。
1. 使用Math.random()生成UUID
这种方法通过调用Math.random()生成随机数,然后将这些随机数拼接起来,形成一个UUID。这种方式生成的UUID有几率与其他生成的UUID相同,因此并不是非常可靠。
2. 使用crypto提供的randomUUID方法
Node.js提供了crypto模块,其中有一个randomUUID方法专门用于生成随机UUID。这种方法生成的UUID具有较高的随机性和独特性,因此在实际开发中被广泛使用。
3. 使用crypto提供的getRandomValues方法
getRandomValues方法用于生成安全的随机数据,适用于需要更高安全级别的场景。这种方式生成的UUID相较于前两种方法更为可靠。
在实际开发中,推荐使用crypto提供的randomUUID方法生成UUID。这是因为该方法生成的UUID既具有较高的随机性,又具有较高的安全性,能够满足大多数开发场景的需求。