让你的javascript函数拥有记忆功能,减少全局变量的使用

考虑如下场景:假如我们需要在界面上画一个圆,初始的时候界面是空白的;当鼠标移动的时候,圆需要跟随鼠标移动,鼠标的当前位置就是圆心。我们的实现方案是:如果界面上还没有画圆,那么就新创建一个;如果已经存在,就直接更新其位置。这样能够避免先销毁,后创建的开销。

var circle = null;

function drawCircle(position)
{
	if(circle == null)
	{
		circle = GUI.Create(position);//创建1个圆
	}
	else
	{
		circle.updatePositon(position);//更新圆的位置
	}
}

这段代码没有什么问题,除了引入了全局变量circle,而实际上circle只会在drawCircle()函数中使用。也就说为了实现if-else的判断,我们不得不使用全局变量。有没有什么方式能够让函数拥有记忆功能,能够记住之前是否创建了圆。这样的话,我们就不用使用全局变量了。

var drawCircle = function(position)
{
	var circle = null;

	function innerFunc(position)
	{
		if(circle == null)
		{
			circle = GUI.Create(position);
		}
		else
		{
			circle.updatePositon(position);
		}
	}

	return innerFunc;
}();

这段代码能够正确的实现需要的功能,而且不会引入没有必要的全局变量。

var drawCircle = function(position)
{

}();

这段代码会定义1个作用域,大括号内部定义的变量和函数,对于外部都是不可见的。而且大括号内部的代码会立刻执行,代码 之前完之后将innerFunc赋值给drawCircle函数。这样的话,就能够缩小变量的作用域。

时间: 2024-10-14 11:40:33

让你的javascript函数拥有记忆功能,减少全局变量的使用的相关文章

让你的javascript函数拥有记忆功能,降低全局变量的使用

考虑例如以下场景:假如我们须要在界面上画一个圆,初始的时候界面是空白的.当鼠标移动的时候,圆须要尾随鼠标移动.鼠标的当前位置就是圆心.我们的实现方案是:假设界面上还没有画圆,那么就新创建一个:假设已经存在,就直接更新其位置.这样可以避免先销毁.后创建的开销. var circle = null; function drawCircle(position) { if(circle == null) { circle = GUI.Create(position);//创建1个圆 } else { c

深入浅出JavaScript函数 v 0.5

本文的观点是建立在<JavaScript权威指南 6th Ed> <JavaScript高级编程 3th Ed> <JavaScript精粹 2th Ed>之上, 笔者将尽所能将概念.原理叙述清楚,由于笔者水平有限,理解不当之处在所难免,请读者不吝交流. 目录 1 什么是函数? 2 函数就是对象! 3 函数字面量(函数表达式) 4 函数调用 4.1 方法调用模式 4.2 函数调用模式 4.3 构造器调用模式 4.4 间接调用模式 5 函数的参数与返回值 6 扩充类型的功

JavaScript函数,作用域以及闭包

JavaScript函数,作用域以及闭包 1. 函数 (1). 函数定义:函数使用function关键字定义,它可以用在函数定义表达式或者函数声明定义. a. 函数的两种定义方式: * function functionName() {} * var functionName = function(){} b. 两种函数定义不同之处 1). 声明提前问题 函数声明语句   :声明与函数体一起提前 函数定义表达式 :声明提前,但是函数体不会提前 请看下面图示:绿色线上面实在js初始加载的时候,查看

第八章:Javascript函数

函数是这样一段代码,它只定义一次,但可能被执行或调用任意次.你可能从诸如子例程(subroutine)或者过程(procedure)这些名字里对函数概念有所了解. javascript函数是参数化的:函数定义会包括一个形参(parmeter)标识符列表.这些参数在函数中像局部变量一样工作.函数会调用会给形参提供实参的值.函数使用它们实参的值计算返回值,成为该函数的调用表达式的值. 除了实参之外,么次调用还会拥有一个值——本地调用的上下文——这就是this关键字值 如果函数挂载在一个对象上,作为对

JavaScript语言精粹读书笔记 - JavaScript函数

JavaScript是披着C族语言外衣的LISP,除了词法上与C族语言相似以外,其他几乎没有相似之处. JavaScript 函数: 函数包含一组语句,他们是JavaScript的基础模块单元,用于代码复用.信息隐藏和组合调用. 函数用于指定对象的行为. 函数对象Functions: 在JavaScript中函数就是对象.对象是"键值"对的集合并拥有一个连接到原型对象的隐藏连接. 对象字面量产生的对象连接到Object.prototype.函数对象连接到Function.prototy

Javascript 函数总结

函数的定义 函数名称只能包含字母.数字.下划线或$,且不能以数字开头.定义时可用函数定义表达式或者函数声明语句. var f = function fact(x){} 函数定义表达式包含名称,名称将作为函数的局部变量,在函数内部使用,代指函数. 函数声明语句不是真正的语句,不能出现在循环.条件.try/catch/finally以及with语句中:声明语句置于在不会执行到的位置,仍可被整个作用域可访问,可在被定义代码之前使用.定义表达式的变量声明被提前了,但是对变量赋值不会提前,函数在被定义之前

[转]JavaScript函数和数组总结

转自:http://www.uml.org.cn/AJAX/201307264.asp 写的不错,对我有很多帮助,最近准备全面的学习研究一下ES5,先转载一下这篇文章. JavaScript函数 1.函数的定义 函数名称只能包含字母.数字.下划线或$,且不能以数字开头.定义时可用函数定义表达式或者函数声明语句. var f = function fact(x){} 函数定义表达式包含名称,名称将作为函数的局部变量,在函数内部使用,代指函数. 函数声明语句不是真正的语句,不能出现在循环.条件.tr

C#实现百度地图附近搜索&amp;调用JavaScript函数

前一篇文章"C#调用百度地图API入门&解决BMap未定义问题"讲述了如何通过C#调用百度API显示地图,并且如何解决BMap未定义的问题.这篇文章主要更加详细的介绍百度地图的一些功能,包括附近搜索.城市搜索.路线规划.添加覆盖物等等. 希望文章对你有所帮助!如果文章中有不足之处,还请海涵~ 百度官方文档:http://developer.baidu.com/map/jsmobile.htm 官方DEMO例:http://developer.baidu.com/map/jsde

被括号括住的JavaScript函数

在JavaScript经常会看到这样的代码 ( function( $ ){ $( 'body' ).css( { 'background-color': '#ccc' } ); } )( jQuery ); 这里的一个JavaScript函数被一个括号括了起来, 然后后面紧跟着一个括号,这种奇葩的写法在其它如Java.VB.c#.c++.php等流行编程语言中根本见不到.这种写法乍一看是JavaScript特意增加的新奇特性, 其实并不是. 在我们编写任何程序时,时时刻刻在用到与上面代码类似的