更多课程 选择中心

Web培训
达内IT学院

400-111-8989

Web培训

Web前端工程师要了解的JavaScript相关知识

  • 发布:Web前端培训
  • 来源:Web开发教程
  • 时间:2020-06-28 13:50

今天小编要跟大家分享的文章是关于Web前端工程师要了解的JavaScript相关知识。正在从事web前端工作的小伙伴们来和小编一起看一看吧,希望本篇文章能够对大家有所帮助。

Web前端工程师要了解的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

递归实现深拷贝

具体实现如下:

/** * 辅助函数, 判定是否是对象 * @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。

以上就是小编今天为大家分享的关于Web前端工程师要了解的JavaScript相关知识的文章,希望本篇文章能够对正在从事web前端工作的小伙伴们有所帮助,想要了解更多web前端相关知识记得关注达内web培训官网,最后祝愿小伙伴们工作顺利,成为一名优秀的web前端工程师

文章来源:原创一叶知秋 杨柳岸XW 

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

预约申请免费试听课

填写下面表单即可预约申请免费试听!怕钱不够?可就业挣钱后再付学费! 怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!

上一篇:Web前端开发工程师要掌握的工具汇总
下一篇:2020年Web前端学习指南

2020年Web前端入门的学习路线总结

Web前端工程师入门必读书籍推荐

做Web前端开发要掌握的知识有哪些

Web前端新手入门必学知识及学习建议

选择城市和中心
黑龙江省

吉林省

河北省

贵州省

云南省

广西省

海南省