js中,(function(){})()的用法解析
经常用,今天总结一下,下文摘自某网友的总结:
(function($){...})(jQuery)实际上是匿名函数,不懂得朋友可以继续往下看。
这里实际上是匿名函数 function(arg){...} 这就定义了一个匿名函数,参数为arg 而调用函数时,是在函数后面写上括号和实参的,由于操作符的优先级,函数本身也需要用括号,即: (function(arg){...})(param) 这就相当于定义了一个参数为arg的匿名函数,并且将param作为参数来调用这个匿名函数 而(function($){...})(jQuery)则是一样的,之所以只在形参使用$,是为了不与其他库冲突,所以实参用jQuery var fn = function($){....}; fn(jQuery);
(funtion(){})();立即执行函数;相当于先申明一个函数,声明完后直接调用;如果参数如:
(funtion(str){alert(str)})("output"));相当于:funtion OutPutFun(str){alert(str);};OutPutFun("output");
最近在整理
javascript
学习,发现这个问题了
,在网上发现这么个解释
最清
楚
最明白
;
(function(){})()
相当于先定义
function xx(){}
,后调用
xx();
()
是最高优先级的,所以先执行
function(){}
,
这个定义了一个匿名函数,等于
xx=function(){}
接着就是调用
xx()
了
;
给个例子
JScript code
functionf1(a)
{
alert(a);
}
functionf2(a)
{
returnfunction(){
alert(a);
}
}
这里的
var x=f2
就等于把函数传递给了
f2,
然后要执行这个函数
,
就必须加
()
也就是
x();
也就是
f2()
还是
(function f2(a){
return function(){
alert(a);
})();
另外还有一个问题
就是命名空间的问题
YY = YY||{};---
声明一个叫
YY
的命名空间(定义一个全局的变量)
(function() {
YY.Lang=function()
{------
声明一个叫
YY.Lang
的命名空间
(通过全局变量的
增加属性的方式把闭包里的对象传到全局变量中,实现代码封装的效果)
isUndefined: function(o) {
return typeof o === 'undefined';
},
isString: function(o) {
return typeof o === 'string';
}
};
})();
---
调用方法
alert(YY.Lang.isString('test me'));
这时候就有人不明了,
楼上为什么要加
(function()
{
和
)();
最外面的这两行,
有什么用啊?
J
Script code
YY=YY||{};
//---
声明一个叫
YY
的命名空间(定义一个全局的变量)
//(
function()
{
YY.Lang=function()
{
//------
声明一个叫
YY.Lang
的命名空间
(通过全局变量的增加属性的方式把闭包里的对象传
到全局变量中,实现代码封装的效果)
isUndefined:function(o)
{returntypeofo==='undefi
ned';
},
isString:function(o)
{returntypeofo==='string';
}
};
}
//)();
//---
调用方法
alert(YY.Lang.isString('test
me'));
疑问在这:??????
注释掉这两行有什么不一样的呢?不就是申明吗,为什么要用
()()执行一下啊?
答:
(
function(){})()
意思是立即执行前一个括号里的
function
,相当于是一个匿名函数
;
由于里面
的代码的执行,
定义了
YY.Lang
这个对象,
所以可以执行
alert(YY.Lang.isString('test
me'));
调用
isString
方法。
但是,如果按照你写的
functionaa(){..};//
只是定义了一个叫
aa的函数,但是并没有执行
alert(YY.Lang.isString('test
me'));//
执行的时候会报找不到
isString
的方法。
这么写有什么好处??????????????
(function{})()
的写法有个好处,就是能很好的利用
javascript
的变量的可见范围为执行脚本
时节省空间。例如以下写法
1和写法2达到的目的是一样的,但是写法1的由于a变量的
可见范围只是在匿名函数体内,
所以a
在执行完这个匿名函数后就释放空间了。
但是写法2
会一直存在该页面中。
写法
1
:
JScript
code
(function(){vara=2;
alert(a);
})();
写法
2
:
JScript
code
vara=2;
alert(a);
js中,(function(){})()的用法解析的更多相关文章
- 熟练掌握js中this的用法,解析this在不同应用场景的作用
由于其运行期绑定的特性,JavaScript 中的 this 含义要丰富得多,它可以是全局对象.当前对象或者任意对象,这完全取决于函数的调用方式. JavaScript 中函数的调用有以下几种方式:作 ...
- [转载]js中return的用法
一.返回控制与函数结果,语法为:return 表达式; 语句结束函数执行,返回调用函数,而且把表达式的值作为函数的结果 二.返回控制,无函数结果,语法为:return; 在大多数情况下,为事件处理函 ...
- [JavaScript] JS中对Base64的解析
JS中对Base64的解析 <script type="text/javascript"> /** * UTF16和UTF8转换对照表 * U+00000000 – U ...
- JS中event.keyCode用法及keyCode对…
js中event.keyCode用法及keyCode对照表 标签: javascriptJavaScriptJavascriptjavaScript 2012-12-11 15:11 HTML Jav ...
- 浅谈JS中 reduce() 的用法
过去有很长一段时间,我一直很难理解 reduce() 这个方法的具体用法,平时也很少用到它.事实上,如果你能真正了解它的话,其实在很多地方我们都可以用得上,那么今天我们就来简单聊聊JS中 reduce ...
- JS中 reduce() 的用法
过去有很长一段时间,我一直很难理解 reduce() 这个方法的具体用法,平时也很少用到它.事实上,如果你能真正了解它的话,其实在很多地方我们都可以用得上,那么今天我们就来简单聊聊JS中 reduce ...
- js中this的用法
经过近几周的模拟面试题,我查询了一些资料,今天就来说说,在js中this的用法吧.方法有四:第一,用作全局变量,第二,用作表该对象,第三,用作构造函数,第四,用作call和applay
- JQuery之append和appendTo的区别,还有js中的appendChild用法
JQuery之append和appendTo的区别 append()前面是要选择的对象,后面是要在对象内插入的元素内容 appendTo()前面是要插入的元素内容且为Jquery对象,而后面是要选择的 ...
- js中function的与众不同
js中function的与众不同在于可以被调用
- MATLAB中冒号的用法解析
MATLAB中冒号的用法解析 1.: 表示所有的意思. (1)如:a(1,:) 表示a的第1行,示例: 结果: 同样的如果a(2,:)表示a的第2行 (2)反过来,a(:,2) 表示a的第3列,示例: ...
随机推荐
- Could Not Connect
今天在写Quartz定时任务web应用时,访问项目页面出现Could Not Connect,后台也没报错. 然后我访问http://127.0.0.1:8080(Apache主页)的时候是正常的. ...
- 如何在Dreamweaver中使用zen coding
在我发表上一篇<Zen Coding: 一种快速编写HTML/CSS代码的方法>之后,有网友表示不知道怎么在Dreamweaver上使用zen coding插件.OK,今天我就写一篇详细的 ...
- B/S VS C/S
从软件project的学习到如今的机房合作,我们一直在学习C/S,进入牛腩才正式进入了对B/S的了解,确切点牛腩则是对此的一个过渡,起到了承上启下的作用!看牛腩,事实上最大的感受就是他不止要设计到页面 ...
- 古老server源代码迁移到新server
因为老vsts资源server不久,准备存档,现在在旧的需要server该代码仍然在使用的所有迁移到新的vstsserver在. 因此,我们需要迁移所有需要也许是习惯了新的代码vsts在之上.代码的迁 ...
- Swift 书面 ToDo App
下面的代码是使用的全部Xcode Version 6.0.1 (6A317)书面. 因为当使用团队开发stroyboard在并购的诸多不便的时间,所有或使用.xib该文件准备ToDo App. 想要实 ...
- POJ 3280 Cheapest Palindrome (DP)
Description Keeping track of all the cows can be a tricky task so Farmer John has installed a sys ...
- hdu1115(重力算法的多边形中心)
标题的含义: 给定一个n刚n顶点.这是获得n分众协调多边形. http://acm.hdu.edu.cn/showproblem.php? pid=1115 题目分析: /** *出处:http:// ...
- SQL Server 移动数据库
原文:SQL Server 移动数据库 移动系统数据库在下列情况下可能很有用: 故障恢复.例如,数据库处于可疑模式下或因硬件故障而关闭. 计划的重定位. 为预定的磁盘维护操作而进行的重定位. 下列过程 ...
- Total Command help
- Oracle中关于处理小数点位数的几个函数,取小数位数,Oracle查询函数
Oracle中关于处理小数点位数的几个函数,取小数位数,Oracle查询函数 关于处理小数点位数的几个oracle函数()1. 取四舍五入的几位小数select round(1.2345, 3) fr ...