我的编程空间,编程开发者的网络收藏夹
学习永远不晚

关于JavaScript相关知识有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

关于JavaScript相关知识有哪些

这期内容当中小编将会给大家带来有关关于JavaScript相关知识有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

  (一)JS中基本类型和引用类型

  JavaScript的变量中包含两种类型的值:基本类型值和引用类型值,在内存中的表现形式在于:前者是存储在栈中的一些简单的数据段,后者则是保存在堆内存中的一个对象。

  •基本类型值

  在JavaScript中基本数据类型有String,Number,Undefined,Null,Boolean,在ES6中,又定义了一种新的基本数据类型Symbol,所以一共有6种。

  基本类型是按值访问的,从一个变量复制基本类型的值到另一个变量后,这两个变量的值是完全独立的,即使一个变量改变了也不会影响到第二个变量。

  let str1 = '你好';

  let str2 = str1;

  str2 = 'hello word'console.log(str2);//'hello word'

  console.log(str1); //'你好'

  •引用类型值

  引用类型值是引用类型的实例,它是保存在堆内存中的一个对象,引用类型是一种数据结构,最常用的是Object,Array,Function类型,此外还有Date,RegExp,Error等。

  在ES6中提供了Set,Map2种新的数据结构。

  (二)JS中如何复制引用类型的

  •基本类型和引用类型赋值的差异化

  举个例子:在下面代码中,只修改了obj1中的name属性,却同时改变了ob1和obj2中的name属性。

  let obj1 = {'name': '小明'};

  let obj2 = obj1;obj2.name = '小兰';

  console.log(obj1); // {'name': '小明'}

  console.log(obj2); // {'name': '小明'}

  当变量复制引用类型值的时候,同样和基本类型值一样会将变量的值复制到新变量上,不同的是对于变量的值,它是一个指针,指向存储在堆内存中的对象。

  因为,在JS中,堆内存中的对象无法直接访问,必须要访问这个对象在堆内存中的地址,然后再按照这个地址去获得这个对象中的值。

  (三)浅拷贝

  在JS中,如果属性是基本类型,拷贝的就是基本类型的值;如果属性是引用类型,拷贝的就是内存地址;所以如果其中一个对象改变了这个地址,就会影响到另一个对象。

  下面是JavaScript提供的浅拷贝方法:

  Object.assign

  ES6中拷贝对象的方法,接受的第一个参数是拷贝的目标,剩下的参数是拷贝的源对象;

  语法:Object.assign(target, ...sources)

  let p = { 'name': 'hello word',};

  let copyP = {};

  Object.assign(copyP, p);

  console.log(copyP);console.log(p);

  Object.assign是一个浅拷贝,它只是在根属性(对象的第一层级)创建了一个新的对象,但是如果属性的值是对象的话,只会拷贝一份相同的内存地址。

  扩展运算符

  利用扩展运算符可以在构造字面量对象时,进行克隆或者属性拷贝。语法如下:

  let cloneObj = { ...obj };

  let obj = {'name': '星期一', 'college': ['星期二','星期三','星期四']}let obj2 = {...obj};

  obj.name='不休息';//{'name': '不休息', 'college': ['星期二','星期三','星期四']}console.log(obj);//{'name': '星期一', 'college': ['星期二','星期三','星期四']}

  console.log(obj2);

  obj.college.push('Go');//{'name': '不休息', 'college': ['星期二','星期三','星期四']}

  console.log(obj); //{'name': '不休息', 'college': ['星期二','星期三','星期四']}

  console.log(obj2);

  扩展运算符和Object.assign()存在同样的问题,对于值是对象的属性无法完全拷贝成两个不同对象;

  但是如果属性都是基本类型的值的话,使用扩展运算符更加简洁。

  (四)深拷贝

  浅拷贝只在根属性上在堆内存中创建了一个新的的对象,复制了基本类型的值,但是复杂数据类型也就是对象则是拷贝相同的地址。

  而深拷贝则是将一个对象从内存中完整的拷贝一份出来,从堆内存中开辟一个新的区域存放新对象,且修改新对象不会影响原对象。

  JSON.stringify

  JSON.stringify()是目前开发过程中最常用的深拷贝方式,原理是把一个对象序列化成为一个JSON字符串,将对象的内容转换成字符串的形式再保存在内存中,再用JSON.parse()反序列化将JSON字符串变成一个新的对象。

  举个例子:

  let obj = { name: '少帅', age: 18, friends: ['阿大', '阿二'], goodF: { name: '水果', age: 19, address: '上海', pets: [{name: '西瓜'}, {name: '苹果'}]}, bir: new Date()};

  let newObj = JSON.parse(JSON.stringify(obj));

  obj.goodF.pets[0].name = '桔子';

  console.log(newObj);console.log(obj);

  使用JSON.stringify实现深拷贝有几点要注意:

  1)拷贝的对象的值中如果有函数,undefined,symbol,经过JSON.stringify()序列化后的JSON字符串中这个键值对会消失;

  2) 无法拷贝不可枚举的属性,无法拷贝对象的原型链

  3)拷贝Date引用类型会变成字符串

  4)拷贝RegExp引用类型会变成空对象

  5) 对象中含有NaN、Infinity和-Infinity,则序列化的结果会变成null

  递归实现深拷贝

  具体实现如下:

  

  function isObj(obj) { return obj instanceof Object;}

  

  function deepCopyObj2NewObj(fromObj, toObj) {

  for (let key in fromObj) {

  if(fromObj.hasOwnProperty(key)){

  let fromValue = fromObj[key]; // 如果是值类型,那么就直接拷贝赋值

  if (!isObj(fromValue)) {

  toObj[key] = fromValue;

  } else { // 如果是引用类型,那么就再调用一次这个方法, // 去内部拷贝这个对象的所有属性 // fromValue是什么类型, 创建一个该类型的空对象

  let tmpObj = new fromValue.constructor;

  // console.log(tmpObj); // debugger;

  deepCopyObj2NewObj(fromValue, tmpObj);

  toObj[key] = tmpObj;

  }

  }

  }}

在日常开发中一般并不需要拷贝很多特殊的引用类型,深拷贝对象使用JSON.stringify是最直接和简单的方法。

实现一个完整的深拷贝是非常复杂的,需要考虑到很多边界情况。对于特殊的引用类型有拷贝需求的话,建议借助第三方完整的库,例如lodash.js。

上述就是小编为大家分享的关于JavaScript相关知识有哪些了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

关于JavaScript相关知识有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Spring Cache相关知识有哪些

这篇文章将为大家详细讲解有关Spring Cache相关知识有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简介 Spring 从 3.1 开始定义了 org.springframework.cach
2023-06-15

Java IO相关知识有哪些

这篇文章主要介绍了Java IO相关知识有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、IO底层是怎么回事?操作系统就是管家,电脑的设备就是资源,如果进程先要操作资源
2023-06-15

HashMap相关知识点有哪些

本篇内容介绍了“HashMap相关知识点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!HashMap 和 HashSet 是 Java
2023-06-17

YARN相关知识点有哪些

本篇内容介绍了“YARN相关知识点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!YARN产生背景为什么会产生YRAN?这个与MapRe
2023-06-19

React的相关知识点有哪些

这篇文章主要介绍“React的相关知识点有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“React的相关知识点有哪些”文章能帮助大家解决问题。React与传统MVC的关系轻量级的视图层库!A J
2023-06-03

C#反射相关知识有哪些

这篇文章主要讲解了“C#反射相关知识有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#反射相关知识有哪些”吧!1、C#反射是什么?Reflection,中文翻译为反射。这是.Net中获
2023-06-17

java Shiro相关知识点有哪些

这篇文章主要介绍了java Shiro相关知识点有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇java Shiro相关知识点有哪些文章都会有所收获,下面我们一起来看看吧。1.权限的管理1.1 什么是权限管
2023-07-06

编程热搜

目录