function fn1(){

  //创建一个数组

  var fns = new Array();

  //i这个变量是保存在fn1这个作用域中

  for(var i=0;i<10;i++){

    //数组中的值是一组函数

    fns[i] = function(){

      return i; 

    } 

  }

  return fns;

}

var fs = fn1();

for(var i=0;i<fs.length;i++){

  //此时通过闭包来调用全部的函数,当要输出i的时候会在它所在的定义域(fn1)中找到它,

  //此时它已变为10。所以连续输出了10个10

  console.log(fs[i]()); 

} //输出:10

---------------------------解决方式------------------------------

function fn1(){

  //创建了一个数组

  var fns = new Array();

  //i这个变量是保存在fn1这个作用域中

  for(var i=0;i<10;i++){

    //num这个变量保存在tf作用域。每个闭包的num都是不一样的

    //所以此时所消耗的内存较大。

    var tf = function(num){

      fns[num] = function(){

        return num; 

      }

    }

    tf(i);

  }

  return fns;

}

var fs = fn1();

for(var i=0;i<fs.length;i++){

  //

  console.log(fs[i]()); 

} //输出:0 ~ 9

---------------------------块作用域------------------------------

for(var i=0;i<10;i++){

   

}

//在js中没有块作用域。无论是使用循环还是推断之后,这个变量一直存在

/**

 * 所以当在全局使用某个变量进行循环或推断之后,这个变量可能会影响到函数的变量,所以

 * 所以在特殊情况下不要使用全局变量。并且全局变量在作用域链的最上层。訪问是最慢的。

 */

console.log(i);

function fn1(){

  console.log(i); 

}

fn1();

/**

 * 在一个团队进行开发中,可能会涉及到定义同名的全局变量,所以在开发中要养成一个好习惯:

 * 将全局变量代码放到一个匿名函数。而且立即调用匿名函数,这样也能够运行全局变量的代码。

 * 可是这些变量被控制在开发者想要控制的作用域中。

*/

解决的方法:将块作用域定义在一个匿名函数中。

(function(){

  for(var i=0;i<10;i++){

   

  }  

})(); //在function的{}后不能直接调用。一定要加把匿名函数放在()内再运行。

---------------------------私有变量------------------------------

function Person(name){

  /**

   *此时没有办法直接訪问name这个属性,由于没有this.name,

   *要訪问name仅仅能通过this.getName获取。通过this.setName设置

   */

  this.setName = function(value){

    name = value;

  } 

  this.getName = function(){

    return name; 

  }

}

var p = new Person("zhang"); //zhang

console.log(p.getName());

p.setName("li");

console.log(p.getName()); //li

/**可是使用这样的方式创建私有变量带来的问题是每一个对象要存储大量函数。

 * 解决办法是通过静态私有变量来解决。

 */

---------------------------解决方式------------------------------

var Person;

(function(){

  //name在函数结束之后就消失,在外面无法使用

  var name = "";

  Person = function(value){

    name = value;

  }

  Person.prototype.setName = function(value){

    name = value;

  }

  Person.prototype.getName = function(){

    return name;

  }

})();

var p1 = new Person("aaa"); //aaa

console.log(p1.getName());

p1.setName("bbb"); //bbb

console.log(p1.getName());

原创文章如转载。请注明出处,本文首发于csdn站点:http://blog.csdn.net/magneto7/article/details/25459099

版权声明:本文博客原创文章。博客,未经同意,不得转载。

js:进一步关闭(范围:下一个)的更多相关文章

  1. 一个js程序:离下一个圣诞节还有多少天?

    话不多说上代码: //离下一个圣诞节还有多少天 var christ=new Date(); christ.setMonth(11); christ.setDate(25); var year=now ...

  2. JS window对象 返回下一个浏览的页面 forward()方法,加载 history 列表中的下一个 URL。

    返回下一个浏览的页面 forward()方法,加载 history 列表中的下一个 URL. 如果倒退之后,再想回到倒退之前浏览的页面,则可以使用forward()方法,代码如下: window.hi ...

  3. js获取上一个月、下一个月格式为yyyy-mm-dd的日期

    /** * 获取上一个月 * * @date 格式为yyyy-mm-dd的日期,如:2014-01-25 */ function getPreMonth(date) { var arr = date. ...

  4. js jquery获取当前元素的兄弟级 上一个 下一个元素

    原博地址:http://www.jb51.net/article/71782.htm var chils= s.childNodes;  //得到s的全部子节点 var par=s.parentNod ...

  5. JS/JQuery获取当前元素的上一个/下一个兄弟级元素等元素的方法

    $(function(){ //遍历获取的input元素对象数组,绑定click事件 var len = $("input[type='file']").length; ; i & ...

  6. js jquery获取当前元素的兄弟级 上一个 下一个元素 jquery如何获取第一个或最后一个子元素

    var chils= s.childNodes;  //得到s的全部子节点 var par=s.parentNode;   //得到s的父节点 var ns=s.nextSbiling;   //获得 ...

  7. JS 如何获取当前上一个月、下一个月和月份所含天数

    在数据报表查询中,经常需要设置查询的日期区间,如查询2018-02-01至2018-02-28的整月数据,这时需要提供快捷整月查询按钮: 如: 一般日期年月日之间由"-"或者&qu ...

  8. 用CSS画小猪佩奇,你就是下一个社会人! js将“I am a coder”反转成 “coder a am I”,不许用split,join,subString,reverse;求解方法三

    用CSS画小猪佩奇,你就是下一个社会人!   欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:江志耿 | 腾讯TEG网络工程师 我是佩奇,哼,这是我的弟弟乔治,呱呱,这是我的妈妈,嚯 ...

  9. js,onblur后下一个控件获取焦点判断、html当前活跃控件、jquery版本查看、jquery查看浏览器版本、setTimeout&setInterval

    需求: input控件在失去焦点后直接做验证,验证通不过的话,显示相应错误.但是如果失去焦点后点击的下个控件是比较特殊的控件(比如,退出系统),那么不执行验证操作,直接退出系统(防止在系统退出前,还显 ...

随机推荐

  1. Qt多工程多目录的编译案例

    源地址:http://blog.csdn.net/libaineu2004/article/details/23625441 写这篇文章的目的是为了让Qt像VC++那样,支持一个工程包含多个项目.即1 ...

  2. ajax提交整个form表单

    在项目开发中,有时提交form表单时不能单单用action或者jquery的 表单提交方法有三种,主要说下第三种 第一种:用form自带属性action提交 第二种:用jquery提交:$(" ...

  3. POJ3436 ACM Computer Factory 【最大流】

    ACM Computer Factory Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5412   Accepted: 1 ...

  4. python 下载整个站点

    用python实现的下载整个站点工具. 核心流程非常easy: 1. 输入站点地址 2. url.得到响应的内容. 3. 依据响应的http报文头,假设类型为html, 则从第4步開始运行. 假设是其 ...

  5. 进阶:案例五: Dynamic 创建 Business Graphic

    效果图: step: 无需节点无需UI 1.添加属性 2.代码: method WDDOMODIFYVIEW . DATA:lr_graph TYPE REF TO cl_wd_business_gr ...

  6. A - Alignment of Code(推荐)

    You are working in a team that writes Incredibly Customizable Programming Codewriter (ICPC) which is ...

  7. 基于visual Studio2013解决面试题之0202上下排

     题目

  8. MFC界面相关(彩色工具栏)

    MFC工具栏控件 创建工具栏步骤: (1)在Resource View中插入新toolbar (2)在toolbar上双击增加按钮,更改ID为ID_BUTTON,编译后在resource.h中即可看到 ...

  9. 开发人员福利!ChromeSnifferPlus 插件正式登陆 Chrome Web Store

    今天(2014-10-30)下午,ChromeSnifferPlus 插件正式登陆 Chrome Web Store. 在线安装地址: https://chrome.google.com/websto ...

  10. 获取信息的有关Windows API(最有意思是OpenProcess和GetProcessMemoryInfo)

    1.窗口信息MS为我们提供了打开特定桌面和枚举桌面窗口的函数.hDesk = OpenDesktop(lpszDesktop, 0, FALSE, DESKTOP_ENUMERATE);// 打开我们 ...