javascript中闭包的概念
2017-11-22 11:12
363 查看
<html> <head> <title>015</title> <script type="text/javascript" charset="utf-8"> //闭包与函数有着紧密的关系。它是函数的代码在运行过程中的一个动态环境,是一个运行期的、动态的概念 //所谓闭包,是指词法表示包括不必计算的变量的函数。也就是说,该函数能够使用函数外定义的变量 //在程序语言中,所谓闭包,是指语法域位于某个特定区域。 //具有持续参照(读写)位于该区域内自身范围之外的执行域上的非持久型变量值能力的段落。这些外部 //执行域的非持久型变量神奇地保留他们在闭包最初定义或创建的值 //定义对象,千万要记住这样定义对象,各属性之间千万要用逗号隔开,而不是分号。 //person={firstname:"John",lastname:"Doe",age:50,eyecolor:"blue"}; /* var name="xiao A"; var obj = { name:"xiao B", getName:function(){ //alert(name); //alert(this.name);//此时这个this表示obj return function(){ return this.name; } } }; obj.getName();//xiao A xiao B //此处注释掉alert(name)和alert(this.name); //document.write(obj.getName());//function (){ return this.name; } var k=obj.getName();//返回的内部匿名函数赋给变量k,k此时是全局变量,相当于直接输入obj.getName();,返回的函数都是在windows下的变量。 alert(typeof k);//function alert(k());//xiao A */ /* var name="xiao A"; var obj = { name:"xiao B", getName:function(){ //this总是指向调用者 var o=this;//此时指的是obj return function(){ return o.name; } } }; alert(obj.getName()());//小b */ //闭包:一个函数可以访问另外一个函数作用域中的变量。 //封闭性,private 起到保护变量的作用 //一级作用域 function f(x){//二级作用域 var temp=x;//局部变量 temp已经没有被使用 return function(x){//三级作用域 temp+=x; //temp又被使用了 alert(temp); } } var a=f(50); //document.write(a);//function (x){ temp+=x; alert(temp); } a(5);//55 a(10);//65 a(20); //85 //相互累加的作用 </script> </head> <body> </body> </html>
相关文章推荐
- javascript和jQuery闭包的概念
- 终于理解了Javascript的闭包概念
- 概念笔记之[javascript<-2->]闭包和封装
- JavaScript的闭包概念
- javascript中闭包的概念
- 深入浅出理解JavaScript的闭包概念
- javascript,jquery(闭包概念)
- Javascript中闭包(Closure)的探索(一)-基本概念
- Javascript编程难点解析,如this,原型,继承,闭包等这些概念
- javascript,jquery闭包概念分析
- JavaScript作用域、闭包、对象与原型链概念及用法实例总结
- javascript中重要概念-闭包-深入理解
- JavaScript学习总结二:js闭包(Closure)概念
- JavaScript高级之-------闭包的概念及其应用
- javascript之块级作用域的概念和闭包
- javascript,jquery闭包概念分析
- JavaScript学习总结二:js闭包(Closure)概念
- javascript中的闭包概念
- JavaScript高级之闭包的概念及其应用
- 深入浅出理解JavaScript的闭包概念