首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

初识js_Js变量理解

大家好,又见面了,我是你们朋友全栈君。   今天看了关于js方面的文章,还是有些云里雾里,对于一个菜鸟来说,学习确实有一定难度,不说别的,能够在网上找到一篇优秀是那样不易。   ...当然之所以难理解,个人觉得是基础知识掌握不牢,因为牵扯到一些前面的东西,比如作用域\等等,如果连基本作用域都没有弄清楚,自然不可能搞懂,还有就是对js实践比较少,因为你根本就不知道什么时候要用这东西...今天我就简单说说我目前所理解,当然可能不完全正确,但是我相信会给你一定启发。   首先我们来谈谈js变量,如果你不知道我为什么要说这些,那么你根本没有掌握js基础,建议回头复习。...如果某个函数被它函数之外一个变量引用,就形成了一个 还有一种更为常用写法 var bi = (function(){ var a = 0; function b(){ a ++; console.log...,而是保存到了内存,所以我们多次打印bi()就成了1、2、3 下面我来说一个使用场景吧。

3.3K20

js

大家好,又见面了,我是你们朋友全栈君。 js一个难点也是它一个特色,是我们必须掌握js高级特性,那么什么是呢?它又有什么用呢?...就是用来解决这一需求本质就是在一个函数内部创建另一个函数。...我们首先知道有3个特性: ①函数嵌套函数函数内部可以引用函数外部参数和变量 ③参数和变量不会被垃圾回收机制回收 本文我们以两种主要形式来学习 在这段代码,a()返回值是一个匿名函数...,这个函数在a()作用域内部,所以它可以获取a()作用域下变量name值,将这个值作为返回值赋给全局作用域下变量b,实现了在全局变量下获取到局部变量变量值 再来看一个经典例子 一般情况下...②作为参数传递 在这段代码函数fn1作为参数传入立即执行函数,在执行到fn2(30)时候,30作为参数传入fn1,这时候if(x>num)num取并不是立即执行函数num,而是取创建函数作用域中

3.2K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS 与模块

    全局变量是“实时”,不会被重围。局部变量在函数执行完后就会被销毁了似乎没有办法防止局部变量被破坏?会有帮助?但是什么是 呢?...:一个能够记住其环境变量函数。...JS真正目的是什么需要 除了纯粹“学术”知识之外,JS还有很多用处: 提供私有的全局变量 在函数调用之间保存变量(状态) JS最有趣应用程序之一是模块模式。...在ES6之前,除了将变量和方法封装在函数之外,没有其他方法可以模块化JS代码并提供私有变量与方法”。与立即调用函数表达式相结合 是至今通用解决方案。...JS 是一种能够“记住”其变量环境函数,即使在后续函数调用之间也是如此。当咱们从另一个函数返回一个函数时,会创建一个,这个模式也称为“工厂函数”。 思考 什么是

    1.1K10

    彻底理解js

    大家好,又见面了,我是你们朋友全栈君。 js一个难点也是它一个特色,是我们必须掌握js高级特性,那么什么是呢?它又有什么用呢?...就是用来解决这一需求本质就是在一个函数内部创建另一个函数。...我们首先知道有3个特性: ①函数嵌套函数函数内部可以引用函数外部参数和变量 ③参数和变量不会被垃圾回收机制回收 本文我们以两种主要形式来学习 ①函数作为返回值 在这段代码,a()返回值是一个匿名函数...,这个函数在a()作用域内部,所以它可以获取a()作用域下变量name值,将这个值作为返回值赋给全局作用域下变量b,实现了在全局变量下获取到局部变量变量值 再来看一个经典例子 一般情况下...②作为参数传递 在这段代码函数fn1作为参数传入立即执行函数,在执行到fn2(30)时候,30作为参数传入fn1,这时候if(x>num)num取并不是立即执行函数num,而是取创建函数作用域中

    72610

    js函数、作用域和

    1、定义: 函数连同它作用域链上要找这个变量,共同构成 2、特点 最大特点,就是它可以“记住”诞生环境,在本质上,就是将函数内部和函数外部连接起来一座桥梁。...3、用处 最大用处有两个 可以读取函数内部变量 暂存数据(让这些变量始终保持在内存,即可以使得它诞生环境一直存在) 4、举个栗子 如果没有这个函数执行后,里面speed变量就会被清理掉...() //1 speedUp() //2 5、经典案例 经典案例是定义一个变量,一个函数,一个return 函数。...这导致car得不到释放,return变量也无法释放,对应所有函数都没有办法释放,就生成了一个 var Car = (function(){ var speed = 0; function...,生成一个

    1.4K20

    理解Python函数

    函数和其相关引用环境组合而成实体。允许函数访问其创建时所在作用域中变量,即使在其定义之外被调用时仍然有效。这种特性使得能够维持一个变量状态,并且可以在函数调用之间保持持久性。...以下是一个简单案例说明概念:def outer_function(outer_var): # 在内部函数 inner_function 引用外部函数变量 outer_var def...outer_var,然后定义了一个内部函数 inner_function,在内部函数引用了外部函数变量 outer_var。...在,inner_function 计算了 inner_var + outer_var,这里 outer_var 保持了其原始状态 10,因此 5 + 10 = 15。...这个例子展示了概念,使得内部函数可以访问外部函数变量,并保持了这些变量状态,从而实现了在函数调用之间共享和保持状态功能。

    19810

    JS

    JS用法给开发带来了极大便利,它使用方式非常自然,以至于很多同学并不很了解,却可以在实际开发顺畅使用了 例如下面的代码,给button添加一个点击事件,很多人经常这么写,实际上这就是一个...要了解,需要先了解下JS变量作用域 变量作用域无非就是两种:全局变量和局部变量 特点是 函数内部可以访问外部变量,函数外部不能访问函数变量 例如 ?...这个实现方式就是 什么是 其实就是将函数内部和函数外部连接起来一座桥梁,可以让函数外部代码访问函数内容变量,可以把简单理解成“定义在一个函数内部函数包在子作用域中保存了一份在父级作用域取得变量...,这些变量不会随父级作用域销毁而销毁,因为他们已经常驻内存了 应用示例 (1)实现公共、私有作用域控制 既然可以对外提供访问内容变量方式,就可以用这个特点实现类似 public private...(2)循环添加DOM事件 先看下面的代码,目标是点击不同输入框给出不同提示 这是个经典案例,开发很容易出现类似错误 ?

    4.2K40

    JS

    定义 是一个拥有许多变量和绑定了这些变量环境表达式(通常是一个函数),因而这些变量也是该表达式一部分。...就是在另一个作用域中保存了一份它从上一级函数或者作用域得到变量,而这些变量是不会随上一级函数执行完成而销毁。 前提条件 计算机内存变量如果有被引用着的话,则系统是不会将之回收。...只要我们能够一直持有这个引用,则就可以令局部变量避免被回收——这是概念成立前提 用途 可以读取到函数内部变量 可以让函数内部变量保持在内存 避免全局变量污染 私有成员存在...注意事项 会让函数变量都被保存到内存,内存消耗较大,不能滥用,否则会导致性能和内存泄漏问题(退出函数之前可以将不用局部变量全部删除) 能改变父函内部变量值,一定要小心使用 示例

    2.5K110

    js

    目录 概念 用途 代码实例 注意点 两个代码片段对比 概念 简单来说,就是定义在一个函数内部函数 用途 可以读取函数内部变量 让这些变量值始终保持在内存...nAdd值是一个匿名函数(anonymous function),而这个匿名函数本身也是一个函数调用相当于后面有两个括号,因为函数f1返回函数名f2。...注意点及解决方法 由于会使得函数变量都被保存在内存,内存消耗很大,所以不能滥用,否则会造成网页性能问题,在IE可能导致内存泄露。...解决方法:在退出函数之前,将不使用局部变量全部删除。 会在父函数外部,改变父函数内部变量值。 解决方法:不要随便改变父函数内部变量值。...返回时牢记一点就是:返回函数不要引用任何循环变量,或者后续会发生变化变量。

    2.3K30

    JS

    : 函数内部嵌套一个函数,内部函数引用外部函数数据,内部函数称之为 示例代码 function fn1(){ var a = 10...return {fn2,fn3} } let {fn2,fn3} = fn1() fn2() // 11 fn3() // 10 在上面的代码示例...存在两个函数 fn2,fn3 生命周期: 产生: 当嵌套内部函数定义完毕之后 执行完之后 就产生 死亡: 当嵌套内部函数不被外界需要时候,就被垃圾回收 包产生条件是: 函数嵌套一个函数...内部函数引用外部函数数据(变量 / 函数) 执行外部函数 作用: 延长局部变量生命周期哦 让函数外部操作函数内部数据( 变量 / 函数) 缺点: 容易造成内存泄漏(内存不能被释放,就会咋成...ncxl) 手动释放null // 手动释放 fn2 = null; fn3 = null; 哈哈哈哈 嘿嘿嘿嘿 //想要获取到标签内容

    9310

    JS

    JS 概念 能够读取其他函数内部变量函数 定义在一个函数内部函数,内部函数持有外部函数内变量引用 简单来说,是指可以访问另一个函数作用域变量函数,一般是定义在外层函数内层函数,但并不仅仅是一个函数...js函数内部可以读取全局变量,函数外部不能读取函数内部局部变量。...function f1(){ var n = 123; function f2(){ //f2是一个 alert(n) } return...f2; } js链式作用域:子对象会一级一级向上寻找所有父对象变量,反之不行。...f2可以读取f1变量,只要把f2作为返回值,就可以在f1外读取f1内部变量 用途 读取函数内部变量 让这些变量值始终保持在内存。不会再f1调用后被自动清除 方便调用上下文局部变量。

    2.5K50

    函数

    (掌握) 是封闭(函数内部函数),是包含(该内部函数对外部作用域而非全局作用域变量引用)。指的是:函数内部函数对外部作用域而非全局作用域引用。...提示:之前我们都是通过参数将外部值传给函数提供了另外一种思路,包起来喽,包起呦,包起来哇。 ?...(x): x = 1 def inner(): print(x) return inner f = outter(1) f() f() f() # 查看元素...__closure__[0].cell_contents: 1 函数应用(掌握) 意义:返回函数对象,不仅仅是一个函数对象,在该函数外还包裹了一层作用域,这使得,该函数无论在何处调用,优先使用自己外层包裹作用域...我们如果使用默认参数也只能解决一个网址,因此我们可以考虑使用方式。

    83520

    JS

    在理解以前.最好能先理解一下作用域链含义,简单来说,作用域链就是函数在定义时候创建,用于寻找使用到变量一 个索引,而他内部规则是,把函数自身本地变量放在最前面,把自身父级函数变量放在其次...,把再高一级函数变量放在更后 面,以此类推直至全局对象为止.当函数需要查询一个变量时候,js解释器会去作用域链去查找,从最前面的本地变量先找,如果 没有找到对应变量,则到下一级链上找...了解了作用域链,我们再来看看js内存回收机制,一般来说,一个函数在执行开始时候,会给其中定义变量划分内存空间保存,以备后面的语句所用,等到函数执行完毕返回了,这些变量就被认为是无用了.对应内存空间也就被回收了....如果在外部函数返回后,又直接调用了内部函数,那么内部函数就无法读取到他所需要外部函数变量值了.所以js解释器在遇到函数定义时候,会自动把函数和他可能使用变量(包括本地变量和父级和祖先级函数变量...(自由变量))一起保存起来.也就是构建一个,这些变量将不会被内存回收器所回收,只有当内部函数不可能被调用以后(例如被删除了,或者没有了指针),才会销毁这个,而没有任何一个引用变量才会被下一次内存回收启动时所回收

    2.5K50

    JavaScript匿名函数函数

    2、 英文单词是closure,这是JavaScript中非常重要一部分知识,因为使用可以大大减少我们代码量,使我们代码看上去更加清晰等等,总之功能十分强大。...含义:说白了就是函数嵌套,内层函数可以使用外层函数所有变量,即使外层函数已经执行完毕(这点涉及JavaScript作用域链)。...,也不容易编写,但如果使用就可以让代码更加清晰 * function delay(x , y , time){ * setTimeout( * function(){ * forTimeout(...x , y) * } * , time); * } */ 3、举例 匿名函数最大用途是创建(这是JavaScript语言特性之一),并且还可以构建命名空间,以减少全局变量使用。...4、注意 4.1 允许内层函数引用父函数变量,但是该变量是最终值 示例六: /** * * * one * two * <li

    1.1K20

    【Node.js】匿名函数--Promise

    javascript, 匿名函数多用于实现回调函数 =函数+引用环境, promise 是ES6语言标准,保存着某个未来才会结束事件(通常是一个异步操作)结果. const promise...因为http.get是异步方法,并不会等待,会继续执行循环,i值随即也会发生变化,而这时异步方法对i引用也就变成了9。我们肯定想输出是不同i值,才能看对应周期数据。怎么办?...// //匿名函数+立即执行 (function (i) { http.get('https://www.baidu.com/...i:0 状态码200 当前i:8 状态码200 当前i:7 状态码200 =函数+引用环境,函数就是匿名函数,引用环境则是传参i值 3.第三个index.js 如果需求就是查看周期:周期数据,这种...别忘了这是异步,定义全局变量let map=new Map();和在异步回调map.set这种是行不通。这时就是Promise登场时候。

    1.8K10
    领券