JavaScript闭包-块级作用域和私有变量
块级作用域
块级作用域是指在由花括号包裹的代码块中的作用域。在JavaScript中是没有块作用域的。为了理解这个概念,来看下面的例子:
for(var i = 0;i < 10; i++){ ...... } alert(i); //结果会输出10
上面的代码中,我们在for循环中定义了变量i,在C++和Java等编程语言中,循环执行结束之后,for循环中的i变量会立刻被垃圾回收。但是在JavaScript中,不管是使用循环或某些判断之后,变量会一直存在。我们可以从打印结果中看到,for循环结束之后打印出的值是10。
当在全局环境中使用某个变量进行循环或判断之后,这个变量可能会影响到函数中的变量,所以在非特殊情况下不要使用全局变量,而且全局变量在作用域链的最上层,访问是最慢的。
解决块作用域的方法是使用匿名函数。来看下面的代码。
(function(){ for(var i = 0; i < 10; i++){ ...... } })(); // 直接打印i值会报错:i没有定义 alert(i); // i is not defined function fn(){ alert(i); } fn();
在上面的代码中,我们通过将代码块放入一个匿名函数中,然后马上调用了这个匿名函数。注意到匿名函数之后的一对括号,它表示调用匿名函数。你可以在很多JavaScript程序中看到这种写法。此时,在匿名函数中的变量在使用完之后就会被回收,在匿名函数外部是访问不到这些变量的。
在我们进行团队开发时,可能会涉及到定义同名的全局变量,所以在开发中我们要养成如下的习惯:将全局变量的代码放入到一个匿名函数中,并且马上调用匿名函数,这样也可以执行全局变量的代码,但是这些变量就被控制在我们想要控制的作用域中了。
私有变量
我们前面在定义一个对象的时候,通过this关键字来设置对象的属性的。通过这种方法设置的属性我们称为公共属性,我们可以通过对象来直接访问这些属性。
在C++和Java等编程语言中,通过private关键字来定义一个对象的私有属性,私有属性不可以被对象直接访问。那么在JavaScript中如何定义私有属性(私有变量)呢?其实也非常简单,我们只需要为对象提供一对set和get方法就可以了。例如下面的代码:
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("Leon"); alert(p.getName());
我们通过this.setName()方法来为对象设置name属性,使用this.getName方法来获取对象的name属性。这样,对象的name属性就是不可以被直接访问的,因为没有this.name属性。
使用上面这种方式创建私有变量带来的问题是每个对象都存储大量的函数,会消耗很多内存。解决这个问题的方法是使用静态私有变量。代码如下:
var name = ""; var Person= function(value){ name = value; } Person.prototype.setName = function(value){ name = value; } Person.prototype.getName = function(){ return name; } var p1 = new Person("Leon"); alert(p1.getName()); p1.setName("Ada"); alert(p1.getName());
通过将setName()和getName()方法放入对象的原型链中,就可以解决方法的多个拷贝的问题。但是上面的代码存在一些安全隐患,就是我们前面所说的块级作用域问题。同样我们可以将这段代码放入匿名函数中来解决这个问题。
(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("Leon"); alert(p1.getName()); p1.setName("Ada"); alert(p1.getName());
将Person类的定义放入到一个匿名函数中,然后立刻执行该匿名函数。这样不但确保了无法使用对象来直接访问属性,也使得每个对象都共享同一份方法的拷贝。
以上就是JavaScript闭包-块级作用域和私有变量的内容,更多相关内容请关注PHP中文网(www.php.cn)!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

如何使用WebSocket和JavaScript实现在线语音识别系统引言:随着科技的不断发展,语音识别技术已经成为了人工智能领域的重要组成部分。而基于WebSocket和JavaScript实现的在线语音识别系统,具备了低延迟、实时性和跨平台的特点,成为了一种被广泛应用的解决方案。本文将介绍如何使用WebSocket和JavaScript来实现在线语音识别系

WebSocket与JavaScript:实现实时监控系统的关键技术引言:随着互联网技术的快速发展,实时监控系统在各个领域中得到了广泛的应用。而实现实时监控的关键技术之一就是WebSocket与JavaScript的结合使用。本文将介绍WebSocket与JavaScript在实时监控系统中的应用,并给出代码示例,详细解释其实现原理。一、WebSocket技

如何使用WebSocket和JavaScript实现在线预约系统在当今数字化的时代,越来越多的业务和服务都需要提供在线预约功能。而实现一个高效、实时的在线预约系统是至关重要的。本文将介绍如何使用WebSocket和JavaScript来实现一个在线预约系统,并提供具体的代码示例。一、什么是WebSocketWebSocket是一种在单个TCP连接上进行全双工

如何利用JavaScript和WebSocket实现实时在线点餐系统介绍:随着互联网的普及和技术的进步,越来越多的餐厅开始提供在线点餐服务。为了实现实时在线点餐系统,我们可以利用JavaScript和WebSocket技术。WebSocket是一种基于TCP协议的全双工通信协议,可以实现客户端与服务器的实时双向通信。在实时在线点餐系统中,当用户选择菜品并下单

JavaScript教程:如何获取HTTP状态码,需要具体代码示例前言:在Web开发中,经常会涉及到与服务器进行数据交互的场景。在与服务器进行通信时,我们经常需要获取返回的HTTP状态码来判断操作是否成功,根据不同的状态码来进行相应的处理。本篇文章将教你如何使用JavaScript获取HTTP状态码,并提供一些实用的代码示例。使用XMLHttpRequest

JavaScript和WebSocket:打造高效的实时天气预报系统引言:如今,天气预报的准确性对于日常生活以及决策制定具有重要意义。随着技术的发展,我们可以通过实时获取天气数据来提供更准确可靠的天气预报。在本文中,我们将学习如何使用JavaScript和WebSocket技术,来构建一个高效的实时天气预报系统。本文将通过具体的代码示例来展示实现的过程。We

JavaScript中的HTTP状态码获取方法简介:在进行前端开发中,我们常常需要处理与后端接口的交互,而HTTP状态码就是其中非常重要的一部分。了解和获取HTTP状态码有助于我们更好地处理接口返回的数据。本文将介绍使用JavaScript获取HTTP状态码的方法,并提供具体代码示例。一、什么是HTTP状态码HTTP状态码是指当浏览器向服务器发起请求时,服务

用法:在JavaScript中,insertBefore()方法用于在DOM树中插入一个新的节点。这个方法需要两个参数:要插入的新节点和参考节点(即新节点将要被插入的位置的节点)。
