当前位置: 首页 > news >正文

JS知识点

1、其他值到字符串的转换规则?

- Null和Undefined类型,null转化为 'null ' ,undefined转化为‘undefined’

- Boolean类型,true转化为‘true’,false转化为 ‘ false’

- Symbol类型的值直接转换,但是只允许显示强制类型转换,使用隐式强制类型转换会产生错误。

强制类型转化:通过一些代码进行类型的转化,更精确地控制特定的数据类型转换例如:Number

隐式类型转化自动完成的类型转换,字符串和数字相加时,JavaScript 引擎会自动将数字转换为字符串,然后将它们连接在一起。

- Number类型的值直接转化。

- 对象:除非自定义的toString()方法,否则会调用对象的原型上的toString()来返回内部属性[object Object],如果对象有自定义的toString()方法,字符串转化时就会调用该方法并使用其返回值.

const obj = {name: "John",age: 30,gender: "male"
};console.log(obj.toString());  // [object Object]

2、 其他值到数字值的转化规则

- Undefined类型的值转化未NaN。

- Null类型的值转化为0.

- Boolean类型的值,true转化为1,false转化为0

- String类型的值转化,使用Numner函数进行转化,如果包含非数字值则转化为NaN,空字符串转化为0.

- 对象:包括数组,

    (1)会首先被转化为相应的基本类型值,如果返回的是非数字的基本类型值,则会将其强制转化为数字。

    (2)JS会自动调用valueOf()来获取一个原始值,如果获取到的值不是一个原始值,JS会继续调用对象的toString方法来回一个字符串,并将该字符串转化为数值。如果既没有valueOf方法也没有toString()方法,那么将会抛出异常。

原始值:Undefined、Null、Boolean、Number、String 和 Symbol。

const obj = {a: 10,toString: function() {return "20";}
};console.log(Number(obj));  // 20

toString() 方法是程序员自己定义的。在 JavaScript 中,大部分对象都继承了 Object 对象的 toString() 方法,该方法默认返回一个字符串 "[object Object]",并不能将对象用于数学运算或者进行类型转换。因此,当我们需要将一个对象转换为数值时,我们需要自定义对象的 valueOf() 或 toString() 方法来返回合适的值。

 3、其他值到布尔类型的值的转换规则?

undefined、null、false、0、NaN都是假值

4、Object.is() 与⽐较操作符 “ === ”、“== ” 的区别?

"==":不全相等,只比较数据,不比较类型,如果两边的类型不一致,会进行强制类型的转化再比较。

"===":全等,不做强制类型的转化,直接返回false,-0和+0相等,两个NaN不相等的。

Object.is:一般情况下和三等号的判断相同,比如-0和+0不再相等,两个NaN是相等的。

5、object.assign和扩展运算法是深拷贝还是浅拷贝,两者区别:

🔰 :深拷贝和浅拷贝:

     -  深拷贝:深拷贝是指对一个对象进行复制,复制出一个新的对象,并且新对象中的每一个属性都是通过递归复制而来的,即新对象和原对象没有任何引用关系

     -  浅拷贝:浅拷贝只会复制对象的基本属性,拷贝出来的新对象和原对象指向通过一内存地址。

object.assign和扩展运算是浅拷贝:
 

let Outobject = {inObject:{a:1,b:2}}
let newObject = {...Outobject}
newObject.inObject.a = 2
console.log(Outobject); //{inObject:{a:1,b:2}}
let Outobject = {inObject:{a:1,b:2}}
let newObject = Object.assign(Outobject)
newObject.inObject.a = 2
console.log(Outobject); //{inObject:{a:1,b:2}}

从代码发现,当newObject将inObject中的a的值改变时,OutObject中的值也发生变化,所以为浅拷贝。

🔰 :区别

1. Object.assign是将所有可枚举属性的值从一个或多个源对象复制到目标对象,如果目标对象已有该属性,则会覆盖该属性,只能拷贝对象的自身属性,可以复制继承属性,但只能复制可枚举的继承属性

2. 扩展运算符用于将一个对象展开为另一个对象的属性。它不复制继承的属性或类的属性但是它会复制ES6 的 symbols 属性

symbols :被用于定义对象的私有属性

 

http://www.lryc.cn/news/66429.html

相关文章:

  • FFmpeg YUV 编码 H264
  • cuda-trt 学习
  • Spot CEO:我们为什么选择Babylon.js而不是Three.js
  • arm安装pyrealsense
  • day36_jdbc
  • C++好难(6):模板初阶
  • Windows 10字体模糊发虚! 如何解决?
  • Spring中的Bean和Bean的生命周期
  • 嘉兴桐乡技能培训提升-如何提高工作效率
  • SystemFunction032函数的免杀研究
  • Shell函数
  • Spring-IOC源码解析
  • 不会做大数据实时计算?10年数据分析师整理,一文给出解决方案
  • 如何让你的 WebSocket 接口测试更高效?拯救你的接口测试工作
  • 浅谈Linux 文件系统层次结构的组织方式
  • 创新案例 |探索 Tive 80% 的收入增长得益于智能物流服务、跟踪和实时可视化
  • makefile和cmake
  • 通过OpenCL内核代码猜测设备寄存器个数
  • C# + .Net6 实现TensorFlow图片分类
  • Ngnix负载均衡和高可用集群及搭建与相关理论
  • 2022年宜昌市网络搭建与应用竞赛样题(三)
  • 为什么PCB设计完成后需要放置mark点
  • 代理IP:IP代理技术与Socks5协议
  • 如何让java程序员生涯更顺利?我聊聊提升技术水平的五个方面
  • 快速排序、希尔排序、归并排序、堆排序、插入排序、冒泡排序、选择排序(递归、非递归)C语言详解
  • ChatGPT一键私有部署,全网可用,让访问、问答不再受限,且安全稳定!
  • 自学黑客(网络安全),一般人我劝你还是算了吧
  • 盘“底座”,盘出新生意经
  • 《花雕学AI》Poe:一个让你和 AI 成为朋友的平台,带你探索 ChatGPT4 和其他 八种AI 模型的奥秘
  • 单片机GD32F303RCT6 (Macos环境)开发 (十五)—— i2c1采用DMA方式的读写函数