发布网友 发布时间:2022-04-24 06:35
共4个回答
热心网友 时间:2022-05-12 07:01
1、相当划出一块私有作用域,避免数据污染。
2、执行完就销毁,避免内存长驻。
var Calculator = function (eq) {
var eqCtl = document.getElementById(eq);
return {
add: function (x, y) { }
};
};
这个函数 跟 (function () {
}());的区别在于返回的add 引用的函数指向内部的定义的那个function(x,y),而它的作用域包含外部那个 function(eq),由于add是全局的,故垃圾回收知道存在引用,故这些函数就会一直存在不会销毁,直到window的环境不存在即浏览器关闭才能释放内存.而匿名的那个执行一次,而本身又没存在外部引用,垃圾回收就会执行~!这就是2者最大区别。
匿名函数最大的用途是来模拟块级作用域,避免数据污染的。
热心网友 时间:2022-05-12 08:19
1,相当划出一块私有作用域,避免数据污染.
2执行完就销毁,避免内存长驻.
var Calculator = function (eq) {
var eqCtl = document.getElementById(eq);
return {
add: function (x, y) { }
};
};
这个函数 跟 (function () {
}());的区别在于返回的add 引用的函数指向内部的定义的那个function(x,y),而它的作用域包含外部那个 function(eq),由于add是全局的,故垃圾回收知道存在引用,故这些函数就会一直存在不会销毁,直到window的环境不存在即浏览器关闭才能释放内存.而匿名的那个执行一次,而本身又没存在外部引用,垃圾回收就会执行~!这就是2者最大区别.
匿名函数最大的用途是来模拟块级作用域,避免数据污染的,追问add 为什么是全局的?
追答抱歉把这里看成返回函数了,这里add只是属性依附所存在对象
,非全局的~!不过在js中只有2个变量类型,全局变量和局部变量.
js规定:所有没用var申明的变量,一律会自动申明为全局变量,所以最好还是明确申明变量.
但有一种情况即使申明了,但还是全局那就是在window中申明,因为那是顶级对象,js中一切都是在window对象下实现的~!
热心网友 时间:2022-05-12 09:53
一般情况下我们定义一个var a=4是window环境下的 就相当于全局变量,如果我们定义在匿名函数中的话就把这个全局环境跟window环境隔开了,避免混淆,而且该匿名函数执行完后就直接销毁了这个匿名函数中定义的变量,释放内存了,但是window的不一样的哇 你关了网页才释放。
热心网友 时间:2022-05-12 11:45
匿名函数执行一次就被销毁了,所以不会在内存中驻留,防止了内存泄露。其次,函数销毁后,防止了其他人调用。追问可是在js 设计模式中 很多时候并不是这样直接自执行 然后销毁的
var Calculator = function (eq) {
var eqCtl = document.getElementById(eq);
return {
add: function (x, y) { }
};
};
比如这样 公开add 私有eqCtl
这样算销毁了吗?
追答这种跟上面那种还是有区别的。因为可以通过变量Calculator 继续调用函数。