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. wince平台下使用log4net记录日志

    前面我写过一篇文章是来介绍windows平台下开发软件使用log4net来记录日志的,详情请参考:用一个简单的示例说明日志记录组件log4net的使用. 我们在wince平台下开发程序也一样需要日志文 ...

  2. boost::asio async_write也不能保证一次发完所有数据 一

    你要是看过basic_stream_socket的文档,里面提到async_write_some不能保证将所有要发送的数据都发出去.并且提到如果想这样做,需要使用boost asio的async_wr ...

  3. SQL 2008 数据库迁移

    1,改动迁移路径 USE master GO ALTER DATABASE 数据库名  --主数据 MODIFY FILE(NAME='数据库名', FILENAME='F:\DataBase\数据库 ...

  4. window2003远程桌面“已达最大连接数”

    使用命令行强制注销远程登录用户 Fri, 04/19/2013 - 09:29 - admin 来源地址: http://space.itpub.net/10067101/viewspace-6147 ...

  5. 数据和C

    整数就是没有小数部分的数,在C中小数点永远不会出现在整数中.例如2,-24,2456都是整数,整数以二进制存储,例如7的二进制表示为111,在8位的字节中存储它的前5位为0,将后3位置1. 浮点数即加 ...

  6. 积累的VC编程小技巧之工具条和状态条

    1.工具条和状态条中控件的添加: 方法⑴.只能在ToolBar里创建控件:首先,在ToolBar中创建一个Button,其ID为ID_TOOL_COMBO(我们要将创建的控件放在该Button的位置上 ...

  7. Windows消息队列

    一 Windows中有一个系统消息队列,对于每一个正在执行的Windows应用程序,系统为其建立一个“消息队列”,即应用程序队列,用来存放该程序可能 创建的各种窗口的消息.应用程序中含有一段称作“消息 ...

  8. Ajax请求URL后加随机数原理

    原文:Ajax请求URL后加随机数原理 例如: $.ajax({             type: "GET",    url: "login.action?ran=& ...

  9. SQLite/嵌入式数据库

    SQLite/嵌入式数据库 的项目要么不使用数据库(一两个文配置文件就可以搞定),要么就会有很多的数据,用到 postgresql,操练sqlite的还没有.现在我有个自己的小测试例子,写个数据库对比 ...

  10. cape town

    开普敦_百度百科 开普敦