西安 [ 更换 ]
热门城市
北京上海广州深圳成都杭州南京武汉天津西安重庆青岛沈阳长沙大连厦门无锡福州济南宁波昆明苏州郑州长春合肥南昌哈尔滨常州烟台南宁温州石家庄太原珠海南通扬州贵阳东莞徐州大庆佛山威海洛阳淮安呼和浩特镇江潍坊桂林中山临沂咸阳包头嘉兴惠州泉州三亚赣州九江金华泰安榆林许昌新乡舟山慈溪南阳聊城海口东营淄博漳州保定沧州丹东宜兴绍兴唐山湖州揭阳江阴营口衡阳郴州鄂尔多斯泰州义乌汕头宜昌大同鞍山湘潭盐城马鞍山襄樊长治日照常熟安庆吉林乌鲁木齐兰州秦皇岛肇庆西宁介休滨州台州廊坊邢台株洲德阳绵阳双流平顶山龙岩银川芜湖晋江连云港张家港锦州岳阳长沙县济宁邯郸江门齐齐哈尔昆山柳州绍兴县运城齐河衢州太仓张家口湛江眉山常德盘锦枣庄资阳宜宾赤峰余姚清远蚌埠宁德德州宝鸡牡丹江阜阳莆田诸暨黄石吉安延安拉萨海宁通辽黄山长乐安阳增城桐乡上虞辽阳遵义韶关泸州南平滁州温岭南充景德镇抚顺乌海荆门阳江曲靖邵阳宿迁荆州焦作丹阳丽水延吉茂名梅州渭南葫芦岛娄底滕州上饶富阳内江三明淮南孝感溧阳乐山临汾攀枝花阳泉长葛汉中四平六盘水安顺新余晋城自贡三门峡本溪防城港铁岭随州广安广元天水遂宁萍乡西双版纳绥化鹤壁湘西松原阜新酒泉张家界黔西南保山昭通河池来宾玉溪梧州鹰潭钦州云浮佳木斯克拉玛依呼伦贝尔贺州通化朝阳百色毕节贵港丽江安康德宏朔州伊犁文山楚雄嘉峪关凉山雅安西藏四川广东河北山西辽宁黑龙江江苏浙江安徽福建江西山东河南湖北湖南海南贵州云南陕西甘肃青海台湾内蒙古广西宁夏香港澳门
培训资讯网 - 为兴趣爱好者提供专业的职业培训资讯知识

好程序员web前端培训分享JavaScript相关知识

培训

  好程序员web前端培训分享JavaScript相关知识,今天跟大家分享的是关于JavaScript相关知识。正在从事web前端工作的小伙伴们来一起看看吧,希望能够对大家有所帮助。

  (一)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

  递归实现深拷贝

  具体实现如下:

  /** * 辅助函数, 判定是否是对象 * @param obj * @returns {boolean} */

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

  /** * 深拷贝fromObj面的所有属性/值, 到toObj对象里面 * @param fromObj 拷贝对象 * @param toObj 目标对象 */

  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;

  }

  }

  }}

  (五)总结

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

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

  

  免责声明:本文图片及文字信息均由小编转载自网络,旨在分享提供阅读,版权归原作者所有,如有侵权请联系我们进行删除。

相关内容

西安第85中“国防人才培训班”“人工智能科学实验班”开始招生

西安市第八十五中学2020年“国防人才预备班”火热招生啦!作为全省首个将部队军事院校优良作风、优秀文化引入普通高中的学校,85中学“国防人才预备班”(以下简称国防班)的建立旨在用军营文化,军事训练感染、塑造学生,为国家培养“政治合格、品学兼···

科美参加飞腾嵌入式培训(西安)会议取得圆满成功

2023年3月2日,科美作为飞腾的生态合作伙伴,继2月份参加成都培训会议之后,再次受邀参加由工业和信息化部人才交流中心指导、飞腾公司主办的 “ 腾珑灵动,赋智未来——2023飞腾嵌入式赋能培训(西安站)巡讲”活动。在本次活动中,飞腾公司培训···

西安市红会医院干部教育培训(三)大数据管理与应用

西安市红会医院党委书记柳明为提升医院大数据应用水平,充分发挥数据价值,推进数字化常态化运行。8月30日下午,西安市红会医院党委在全院中层干部范围内组织开展了大数据应用培训工作。院领导班子成员及全体中层干部、支部书记100余人参加了会议。西安···

知点考博:西安交通大学人工智能学院22年考博招生简章

知点考博:本文整理自学校官方信息,更多考研考博资讯,欢迎关注我们!西安交通大学电子与信息学部人工智能学院2022年博士研究生普通招考“申请-考核”制实施细则为了选拔和培养适应现代科学和技术发展需求的优秀创新人才,积极探索新的博士研究生招生与···

西安专业的游戏设计开发培训机构,办学二十年,教一个教好...

游戏设计培训,手把手教学线下面授零基础入门。从事游戏设计专业时,游戏设计专业使您可以进入游戏,并能够开发用户界面和其他元素。但这将做的更多。他将教您如何在视频游戏之外的环境中释放用户体验。您将可以设计任何类型的用户界面或任何计算机软件,这超···

第一批读人工智能的「双非」学生,抓住风口了吗?

随着ChatGPT的爆火,人工智能成为近来人们最关注的焦点之一。创业者争相进场,大厂也招兵买马,为AI人才开出年薪百万的消息见怪不怪。与此同时,人工智能热也在高校内蔓延。2018年,国内35所高校率先获得人工智能专业建设资格,其中多数是实力···

西安Java培训机构哪家好?

哪家好?或好与不好?得看取决于自身的评判的标准有人就喜欢品牌效应 觉得知名就是好的!则贵出名就是对。(上一辈的选择观大部分是靠这个)有人恰恰相反觉得小的就出精品。(前提是小机构能好好活着)自控力不足想培训,是大多数人的原因,在家自学,网上看···

一个合格的嵌入式开发者有以下几个指标可以来考核一下

当你从事嵌入式开发的时候,不太可能让你一个人设计一个完整的系统,通常只是参与设计一个小模块,因此直接学大框架设计是没有必要的,嵌入式开发人员最需要的是基本功,所以,先锻炼好C语言能力。看书不会让你少走多少弯路,动手编码才能真正让你少走弯路。···

腾讯云培训认证体系将打造云计算“黄埔军校”

10月18日,由腾讯公司与西安高新区管委会主办,腾讯云与西安软件园发展中心承办的腾讯“云+未来”峰会西安站正式召开,探讨云计算如何助力西安开拓“数字丝绸之路”。腾讯云针对西安产业发展特点,全面推出大数据、云安全、混合云、海外化等解决方案,还···

学室内设计哪个学校好?室内设计专业的高校有哪些?

今天,小编就来跟大家分享一下开展室内设计专业的学校有哪些?学室内设计哪个学校好?希望对想要进入这个行业的小伙伴有所帮助。在此,简单介绍十一所室内设计专业比较不错的高校,排名不分前后:1、清华大学美术学院2、中央美术学院3、中国美术学院4、西···

选择Java培训机构具备这几点就是靠谱的IT培训机构

培训机构没有哪家好之说,只有适合之言,Java机构只有适合自己的才是最好的,像我觉得面授教学,好的学习氛围,老师可以随时帮忙解决困难的机构才是好机构,那我就去找这样的机构,选择适合自己的机构才能称之为最好的机构。不过本人觉得在选择机构的时候···

不让西安Java培训价格阻碍你的成功

虽然学习是一种投资,但在选择西安Java培训 机构的过程中,价格因素也是我们需要重点衡量的一个标准,是影响大多数学员做出抉择时的重要因素。那市面上西安Java培训班 的价格如何呢?随着互联网的成熟发展,相应的金融理财也随之兴起,不少培训机构···

西安Java程序员培训与自学那种方式更适合我们学习

目前,西安的状况就是,越来越多的Java人才已经供不应求,为此也有不少人想要成为Java软件开发工程师,根据了解,现在的Java培训层出不穷,对于零基础的同学来说,越来越明白参加培训的重要性,但想要掌握Java编程技术,就一定只有参加西安培···

友情链接