前端面试题(十七)

95. 深拷贝和浅拷贝的区别

  • 浅拷贝
    浅拷贝只复制对象的第一层属性,子对象仍然是引用类型。如果修改子对象的属性,原对象中的相应属性也会被修改。

    常见的浅拷贝方法

    • Object.assign()
    • 数组的 slice()concat()

    示例

    const obj1 = {
          a: 1, b: {
          c: 2 } };
    const obj2 = Object.assign({
         }, obj1);
    obj2.b.c = 3;
    console.log(obj1.b.c); // 3,原对象也受影响
    
  • 深拷贝
    深拷贝会递归复制对象的所有属性,包括子对象,确保拷贝对象和原对象之间完全独立。

    常见的深拷贝方法

    • JSON.parse(JSON.stringify())(局限于不支持函数、undefined
    • 自定义递归函数

    示例

    const obj1 = {
          a: 1, b: {
          c: 2 } };
    const obj2 = JSON.parse(JSON.stringify(obj1));
    obj2.b.c = 3;
    console.log(obj1.b.c); // 2,原对象不受影响
    

96. ES6 模块化

  • 模块化的定义
    模块化是一种将代码拆分成独立、可复用部分的技术,每个模块只负责实现特定的功能。在 ES6 之前,常用的模块化方案有 CommonJS(Node.js 使用)和 AMD。ES6 引入了新的模块化标准,使用 importexport 关键字。

  • ES6 模块的特性

    1. 静态解析:模块在编译时就确定依赖关系,而不是在运行时加载。
    2. 按需导入:通过 import 可以只导入模块中需要的部分,提高性能。
  • 示例

    模块的导出

    // math.js
    export const add = (a, b) => a + b
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小于负无穷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值