ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

JavaScript进阶——面向对象ES6(四)

2022-05-25 01:00:08  阅读:154  来源: 互联网

标签:闭包 ES6 局部变量 进阶 作用域 JavaScript 拷贝 变量 函数


闭包

变量作用域

变量根据作用域的不同分为两种:全局变量和局部变量。

  1. 函数内部可以使用全局变量。

  2. 函数外部不可以使用局部变量。

  3. 当函数执行完毕,本作用域内的局部变量会销毁。


什么是闭包

闭包(closure)指有权访问另一个函数作用域中的变量的函数。 -----JavaScript高级程序设计。

简单理解就是,一个作用域可以访问另外一个函数内部的局部变量。

闭包主要作用:延伸了变量的作用范围。代码如下所示,使用高阶函数创建闭包:

function func(){
    var number = 100;
    return function(){
        console.log(number);
    }
}
var otherFunc = func();
otherFunc();


递归

什么是递归?

如果一个函数在内部可以调用其本身,那么这个函数就是递归函数
简单理解:函数内不自己调用自己。这个函数就是递归函数。

浅拷贝和深拷贝

  1. 浅拷贝只是拷贝一层,更深层次对象级别的值拷贝引用。
  2. 深拷贝多层,每一级的数据都会拷贝。
  3. Object.assign(target,...sources) es6新增方法可以浅拷贝。

标签:闭包,ES6,局部变量,进阶,作用域,JavaScript,拷贝,变量,函数
来源: https://www.cnblogs.com/maplerain/p/16307842.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有