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

初识js_Js变量理解

今天看了关于js方面的文章,还是有些云里雾里,对于一个菜鸟来说,学习确实有一定的难度,不说别的,能够在网上找到一篇优秀的是那样的不易。   ...当然之所以难理解,个人觉得是基础知识掌握的不牢,因为牵扯到一些前面的东西,比如作用域\等等,如果连基本的作用域都没有弄清楚,自然不可能搞懂,还有就是对js的实践比较少,因为你根本就不知道什么时候要用这东西...今天我就简单的说说我目前所理解的,当然可能不完全正确,但是我相信会给你一定的启发。   首先我们来谈谈js的变量,如果你不知道我为什么要说这些,那么你根本没有掌握js的基础,建议回头复习。...var age = 20; 3 } 4 a(); 5 console.log(age); >> Uncaught ReferenceError: age is not defined 注意点1:在函数如果不使用...所以我们多次打印bi()就成了1、2、3 下面我来说一个使用场景吧。

3.3K20

js

js的一个难点也是它的一个特色,是我们必须掌握的js高级特性,那么什么是呢?它又有什么用呢?...我们首先知道有3个特性: ①函数嵌套函数 ②函数内部可以引用函数外部的参数和变量 ③参数和变量不会被垃圾回收机制回收 本文我们以两种的主要形式来学习 在这段代码,a()的返回值是一个匿名函数...原来由于js是单线程的,所以在执行for循环的时候定时器setTimeout被安排到任务队列中排队等待执行,而在等待过程for循环就已经在执行,等到setTimeout可以执行的时候,for循环已经结束...(ps:如果把for循环里面的var变成let,也能实现预期结果) 引入来保存变量i,将setTimeout放入立即执行函数,将for循环中的循环值i作为参数传递,100毫秒后同时打印出1 2...,解决方法是可以在使用完变量后手动为它赋值为null; ②其次由于涉及跨域访问,所以会导致性能损失,我们可以通过把跨作用域变量存储在局部变量,然后直接访问局部变量,来减轻对执行速度的影响 发布者:

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

Js的概念和具体使用

前言 包在js里面是一个比较抽象的概念,但在面试里,是一个必问的话题,往往面试官希望你列举一些使用的例子或手写一个 ,简单一句话讲就是能够读取其他函数内部变量的函数,当需要函数内容部的变量被外部的代码所访问时...,被外部的变量和代码所访问和使用 当a函数内部的函数被a函数以外的函数所访问到,那就可以称为一个 最常见的用途就是把一个变量永久的保存下来,而不是随着函数的执行完毕而被js的垃圾回收器所回收...那这样,也会带来一个问题,就是内存得不到及时的回收,有可能会产生内存溢出的危险,具体的解决办法就是,退出函数之前,将不使用的局部变量全部删除清空就可以了 如果你把父函数当做对象使用,把当做它的公有方法...,把内部变量当做它的私有属性,这时候,要注意不要随便的改变父函数的内部变量的值 03 的用途 对外提供公有属性和方法(也就是函数外部读取函数内的局部变量) 保存变量于内存,避免全局变量的污染(上面的一个示例就是的...,局部变量被保存下来了的) 有时候需要一个模块定义这样的变量,执行某些操作后,始终保存上一次的值,希望这个变量一直保存在内存,但又不会污染全局变量,这个时候,我们就可以使用 总结 的概念比较抽象

1K30

js

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

2.3K30

JS

JS用法给开发带来了极大的便利,它的使用方式非常自然,以至于很多同学并不很了解,却可以在实际开发顺畅的使用了 例如下面的代码,给button添加一个点击事件,很多人经常这么写,实际上这就是一个...要了解,需要先了解下JS变量的作用域 变量的作用域无非就是两种:全局变量和局部变量 特点是 函数内部可以访问外部变量,函数外部不能访问函数内的变量 例如 ?...这个实现方式就是 什么是 其实就是将函数内部和函数外部连接起来的一座桥梁,可以让函数外部的代码访问函数内容变量,可以把简单理解成“定义在一个函数内部的函数” 包在子作用域中保存了一份在父级作用域取得的变量...(2)循环添加DOM事件 先看下面的代码,目标是点击不同的输入框给出不同的提示 这是个经典案例,开发很容易出现类似错误 ?...原因 第一种方式出现错误,是因为在for循环结束后,变量item的值已经变为了最后一项,所以当点击事件执行时,读取的信息总是最后一项的信息 而第二个方式就是利用了会把父级变量保存到自己作用域的特点

4.2K40

JS

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

2.5K110

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; 哈哈哈哈 嘿嘿嘿嘿 //想要获取到标签的内容

6610

JS

JS 概念 能够读取其他函数内部变量的函数 定义在一个函数内部的函数,内部函数持有外部函数内变量的引用 简单来说,是指可以访问另一个函数作用域变量的函数,一般是定义在外层函数的内层函数,但并不仅仅是一个函数...js函数内部可以读取全局变量,函数外部不能读取函数内部的局部变量。...为什么需要 局部变量无法共享和长久的保存,而全局变量可能造成变量污染,所以我们希望有一种机制既可以长久的保存变量又不会造成全局污染 何时使用?...变量既想反复使用,又想避免全局污染 用法 定义外层函数,封装被保护的局部变量 定义内层函数,执行对外部函数变量的操作 外层函数返回内层函数的对象,并且外层函数被调用,结果保存在一个全局的变量 从外部读取函数内部的变量...function f1(){ var n = 123; function f2(){ //f2是一个 alert(n) } return

2.5K50

JS

在理解以前.最好能先理解一下作用域链的含义,简单来说,作用域链就是函数在定义的时候创建的,用于寻找使用到的变量的值的一 个索引,而他内部的规则是,把函数自身的本地变量放在最前面,把自身的父级函数的变量放在其次...,把再高一级函数的变量放在更后 面,以此类推直至全局对象为止.当函数需要查询一个变量的值的时候,js解释器会去作用域链去查找,从最前面的本地变量先找,如果 没有找到对应的变量,则到下一级的链上找....如果在外部函数返回后,又直接调用了内部函数,那么内部函数就无法读取到他所需要的外部函数变量的值了.所以js解释器在遇到函数定义的时候,会自动把函数和他可能使用的变量(包括本地变量和父级和祖先级函数的变量...(自由变量))一起保存起来.也就是构建一个,这些变量将不会被内存回收器所回收,只有当内部的函数不可能被调用以后(例如被删除了,或者没有了指针),才会销毁这个,而没有任何一个引用的变量才会被下一次内存回收启动时所回收...Js代码 function f1(){ var n=999; } alert(n); // error 这里有一个地方需要注意,函数内部声明变量的时候,一定要使用var命令。

2.5K50

JS 与模块

会有帮助吗?但是什么是 呢?...JS的真正目的是什么的需要 除了纯粹的“学术”知识之外,JS还有很多用处: 提供私有的全局变量 在函数调用之间保存变量(状态) JS最有趣的应用程序之一是模块模式。...在ES6之前,除了将变量和方法封装在函数之外,没有其他方法可以模块化JS代码并提供私有变量与方法”。与立即调用的函数表达式相结合 是至今通用解决方案。...有时全局变量是有用的,需要格外小心使用,因为JS引擎可以自由地创建全局变量。 这些年来出现了许多模式来管理全局变量,模块模式就是其中之一。模块模式建立在包上,这是JS的固有特性。...JS 是一种能够“记住”其变量环境的函数,即使在后续函数调用之间也是如此。当咱们从另一个函数返回一个函数时,会创建一个,这个模式也称为“工厂函数”。 思考 什么是

1.1K10

彻底理解js

js的一个难点也是它的一个特色,是我们必须掌握的js高级特性,那么什么是呢?它又有什么用呢?...我们首先知道有3个特性: ①函数嵌套函数 ②函数内部可以引用函数外部的参数和变量 ③参数和变量不会被垃圾回收机制回收 本文我们以两种的主要形式来学习 ①函数作为返回值 在这段代码,a()的返回值是一个匿名函数...原来由于js是单线程的,所以在执行for循环的时候定时器setTimeout被安排到任务队列中排队等待执行,而在等待过程for循环就已经在执行,等到setTimeout可以执行的时候,for循环已经结束...(ps:如果把for循环里面的var变成let,也能实现预期结果) 引入来保存变量i,将setTimeout放入立即执行函数,将for循环中的循环值i作为参数传递,100毫秒后同时打印出1 2...,解决方法是可以在使用完变量后手动为它赋值为null; ②其次由于涉及跨域访问,所以会导致性能损失,我们可以通过把跨作用域变量存储在局部变量,然后直接访问局部变量,来减轻对执行速度的影响 发布者:

72110

js面试题经典_js原理

我相信如果你不是非常理解JavaScript,一定是不想看这段代码的。...var a=fun(0),传入一个参数0,那就是说,函数fun参数 n 的值是0了,而返回的那个对象,需要一个参数n,而这个对象的作用域中没有n,它就继续沿着作用域向上一级的作用域中寻找n,最后在函数...undefined 0 1 1 最开始的代码来自这里 http://www.cnblogs.com/xxcanghai/p/4991870.html 这篇文章只是针对这道题讲了讲,没有非常着重的去讲这个概念...,所以如果朋友们,对详细的概念还不是很理解,要赶紧学习了。...顺便推荐几篇讲解的文章 学习Javascript(Closure) Javascript——懂不懂由你,反正我是懂了 JS可被利用的常见场景 发布者:全栈程序员栈长,转载请注明出处

2.9K20

JavaScript之for循环

之前讲了最简单的,然而最经典的是那个for循环,几乎每一个想要理解的都会遇到这个例子,每一个讲解的也会举这个例子。我这次不是要讲这么解决这个for循环问题,而是解释这个。...[2].click=function(){alert(i);}; 我们都知道GC机制了,i由于被函数引用,所以i不会被回收,那么i最后存储在内存是3,当我们点击的时候从内存获取的就是循环完了之后的3...使用解决,函数变成这样: for(var i = 0; i < liArr .length; i++){ liArr [i].onclick = (function(arg){...return function () { alert(arg) } })(i) }; 就是创建一个,这个是一个立即执行函数,然后返回一个函数。...对不是很理解的可以参考着看初识的文章,你就很容易理解了。当然,对于解决这个问题还有很多方法,这边只是分析的原理。

62810
领券