当前位置: 首页 > 编程笔记 >

JavaScript中的闭包介绍

田英卓
2023-03-14
本文向大家介绍JavaScript中的闭包介绍,包括了JavaScript中的闭包介绍的使用技巧和注意事项,需要的朋友参考一下

所谓的闭包应该是指: 内部函数读取当前函数以外的变量,即创建时所处的上下文环境。


function hello(){

    var char = "hello,world";

    function print(){

        console.log(char);

    };

    return print();

}


需要注意的是这里的print函数引用了外部hello函数的char变量,于是在这里我们能够返回一个

hello,world


而这个功能在某种意义上来说,应该是要归功于作用域。当然了,我们没有办法直接访问char,除非是我们声明这个变量的时候出错了。如

function hello(){

    char = "hello,world";

    function print(){

        console.log(char);

    };

    return print();

}


仅仅是因为少了个var。


在这里hello变成一个闭包 了。 闭包是一种特殊的对象。它由两部分构成:函数,以及创建该函数的环境。环境由闭包创建时在作用域中的任何局部变量组成。

Javscript 闭包与this

需要注意的是读取this与arguments时,可能是会出问题的。


function hello(){

    this.char = "hello,world";

    function output(){

        char = "I'm no hello world";       

        console.log(this.char);

    };

    return output();

}


当然了这个例子并不够贴切,so,我们需要一个额外的例子来解释这个问题,下面引用一个《Javascript高级程序设计》中的一个例子,来说明这个问题。

var name = "The window";

var object = {     name: "My Object",

    getNameFunc: function(){         return function(){             return this.name;         }     } }; object.getNameFunc()()


只是这种用法实在是,而解决方法便是保存一个临时变量that,如之前在《关于Javascript的this的一些知识》一文中所说的。


var name = "The window";

var object = {

    name: "My Object",

    getNameFunc: function(){         var that = this;         return function(){             return that.name;         }     } }; object.getNameFunc()()


Javscript 闭包与读写变量
值得注意的是,如果我们没有处理好我们的变量时,我们也可以修改这些变量。

function hello(){

    var char = "hello,world";

    return{

        set: function(string){

            return char = string;

        },

        print: function(){

            console.log(char)

        }

    }

}

var say = hello();

say.set('new hello,world') 

say.print() // new hello world


Javascript 闭包与性能

引用MDC的说法


 如果不是因为某些特殊任务而需要闭包,在没有必要的情况下,在其它函数中创建函数是不明智的,因为闭包对脚本性能具有负面影响,包括处理速度和内存消耗。


文上还说到。

 例如,在创建新的对象或者类时,方法通常应该关联于对象的原型,而不是定义到对象的构造器中。原因是这将导致每次构造器被调用,方法都会被重新赋值一次(也就是说,为每一个对象的创建)。

 类似资料:
  • 本文向大家介绍JavaScript中的闭包(Closure)详细介绍,包括了JavaScript中的闭包(Closure)详细介绍的使用技巧和注意事项,需要的朋友参考一下 闭包是JavaScript中一个重要的特性,其最大的作用在于保存函数运行过程中的信息。在JavaScript中,闭包的诸多特性源自函数调用过程中的作用域链上。   函数调用对象与变量的作用域链   对于JavaScript中的每

  • 主要内容:什么是闭包,闭包的用途,闭包的高级用法闭包(closures)是 Javascript 语言的一个难点,也是它的特色,很多高级应用都是依靠闭包实现的。闭包与变量的作用域以及变量的生命周期密切相关,本节我们就来简单介绍一下。 什么是闭包 所谓闭包,指的就是一个函数。当两个函数彼此嵌套时,内部的函数就是闭包。 因为在 JavaScript 中,函数属于对象,对象又是属性的集合,而属性的值又可以是对象,所以我们可以在函数内部再定义函数。例如

  • 本文向大家介绍JavaScript中的包装对象介绍,包括了JavaScript中的包装对象介绍的使用技巧和注意事项,需要的朋友参考一下 javascript对象是一种复合值,它是属性或已命名的值的集合,通过符号"."来引用属性值,当属性值是一个函数的时候,我们称之为方法。我们看到字符串也具有属性和方法: 字符串既然不是对象,为什么它又有属性呢,只要引用了字符串s的属性,javascript就会将字

  • 闭包 函数对象可以通过作用域链关联起来,函数体内的变量可以保存在作用域中,这种特性称“闭包”。 要理解闭包,首先要理解嵌套函数的词法作用域规则:先看下列一段代码: var a = "Tom"; //全局变量 function curr () { var a = "Bob"; //局部变量 function () { return a; } ret

  • 闭包是较难理解的概念,Python 初学者可以暂时跳过此节。学习此节时需要理解 “函数是第一类对象” 的概念,在词条 “Python 的 lambda 表达式” 中详细介绍了这一概念。 本节首先讲解理解闭包所需要的铺垫知识,最后再引入闭包的定义。 1. 嵌套定义函数 1.1 在函数内部定义函数 Python 允许嵌套定义函数,可以在函数中定义函数,例如: def outter(): def

  • 本文向大家介绍Python、Javascript中的闭包比较,包括了Python、Javascript中的闭包比较的使用技巧和注意事项,需要的朋友参考一下 同为脚本语言,python和Javascript具有相似的变量作用域,不像php,函数的内部的所有变量和外部都是隔绝的,也就是说,函数要想处理其外部的数据,必须使用参数把需要处理的数据传递进来(使用global关键词这里不讨论),而python