js匿名函数运行的方法
Javascript中定义函数的方式有多种,函数直接量就是其中一种。如var fun = function(){},这里function如果不赋值给fun那么它就是一个匿名函数。好,看看匿名函数的如何被调用。
方式1,调用函数,得到返回值。强制运算符使函数调用执行
|
1
2
3
4
|
(function(x,y){ alert(x+y); return x+y;}(3,4)); |
方式2,调用函数,得到返回值。强制函数直接量执行再返回一个引用,引用再去调用执行
|
1
2
3
4
|
(function(x,y){ alert(x+y); return x+y;})(3,4); |
这种方式也是很多库爱用的调用方式,如jQuery,Mootools。
方式3,使用void
|
1
2
3
4
|
void function(x) { x = x-1; alert(x);}(9); |
方式4,使用-/+运算符
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
-function(x,y){ alert(x+y); return x+y;}(3,4);+function(x,y){ alert(x+y); return x+y;}(3,4);--function(x,y){ alert(x+y); return x+y;}(3,4);++function(x,y){ alert(x+y); return x+y;}(3,4); |
方式5,使用波浪符(~)
|
1
2
3
4
|
~function(x, y) { alert(x+y); return x+y;}(3, 4); |
方式6,匿名函数执行放在中括号内
|
1
2
3
|
[function(){ console.log(this) // 浏览器得控制台输出window}(this)] |
方式7,匿名函数前加typeof
|
1
2
3
|
typeof function(){ console.log(this) // 浏览器得控制台输出window}(this) |
方式8,匿名函数前加delete
|
1
2
3
|
delete function(){ console.log(this) // 浏览器得控制台输出window}(this) |
方式9,匿名函数前加void
|
1
2
3
|
void function(){ console.log(this) // 浏览器得控制台输出window}(this) |
方式10,使用new方式,传参
|
1
2
3
|
new function(win){ console.log(win) // window}(this) |
方式11,使用new,不传参
|
1
2
3
|
new function(){ console.log(this) // 这里的this就不是window了} |
方式12,逗号运算符
|
1
2
3
|
1, function(){ console.log(this) // window}(); |
方式13,按位异或运算符
|
1
2
3
|
1^function(){ console.log(this) // window}(); |
方式14,比较运算符
|
1
2
3
|
1>function(){ console.log(this) // window}(); |
最后看看错误的调用方式
|
1
2
3
4
|
function(x,y){ alert(x+y); return x+y;}(3,4); |
js匿名函数运行的方法的更多相关文章
- JS匿名函数的理解
js匿名函数的代码如下:(function(){ // 这里忽略jQuery 所有实现 })(); 半年前初次接触jQuery 的时候,我也像其他人一样很兴奋地想看看源码是什么样的.然而,在看到源码的 ...
- js匿名函数和闭包总结
js匿名函数和闭包总结 一.总结 一句话总结:匿名函数的最主要作用是创建闭包,闭包就是将函数内部和函数外部连接起来的一座桥梁.内层的函数可以使用外层函数的所有变量,即使外层函数已经执行完毕.闭包可以用 ...
- js匿名函数(变量加括号就是函数)
js匿名函数(变量加括号就是函数) 一.总结 变量加括号就是函数,而函数的括号是用来传参的 1.类比:以正常函数去想匿名函数,匿名函数比正常函数只是少了函数名,本质还是一样,该怎么传参还是怎么传参,小 ...
- js匿名函数确实是个好东西
<body onload="alert('http://www.baidu.com/');"> <script type="text/javascrip ...
- JS匿名函数自执行函数
JS匿名函数自执行函数:(function(){})();(function(){}) 这是一个函数,函数后面接(),则是调用函数 比如(function(arg){console.log(arg); ...
- js匿名函数自执行的好处
我们知道,在创建一个函数时如果要用到变量来存取信息的话,要尽量使用局部变量. 因为一方面局部变量会随着函数的执行结束被销毁:另一方面在不执行函数的时候也不会创建这个局部变量,对节省空间资源有很大的好处 ...
- js匿名函数测试
js匿名函数测试 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> < ...
- js 匿名函数 js-函数定义方法
1.任何函数都是有返回值的,没有返回值的,在某些语言里称之为过程例如PL/SQL 2.js中的函数如果没有return 关键字指明给出的返回值,那么当调用完函数后,会返回“undefined" ...
- js 匿名函数-立即调用的函数表达式
先提个问题, 单独写匿名函数为什么报错?return 匿名函数 为什么不报错? 如图: 第二种情况在 f 还没有执行的时候,就报错了,,,当然这得归因于函数声明语句声明提前(发生在代码执行之前)的原因 ...
随机推荐
- 粗看ES6之字符串
标签: javascript es6 字符串新增特性 新增二个方法 - startsWith/endsWith 字符串模板 - 反单引号的应用 startsWith 判断字符串以是否以某某开头,返回一 ...
- Eclipse+ADT+Android SDK 搭建安卓开发环境(转)
要求 必备知识 windows 7 基本操作. 运行环境 windows 7(64位); eclipse-jee-luna-SR2-win32(32位);ADT-23.0.4 下载地址 环境下载 最近 ...
- js报错 object is not a function
主要是js函数名重名了,重命名就可以了.
- check_mk 之 Configuration variables
Basic settings #check_parameters This is a configuration list assigning specific check parameters to ...
- 使用 javascript API -- fetch 实现文件下载功能
下载原理 下载原理很简单,就是模拟 a 标签的点击下载,我们都知道 ajax 不支持下载文件功能,是因为 ajax 只能用来传输字符型数据,所以在过去无法使用 ajax 来下载文件. xhr2 可以把 ...
- SourceTree Win10 安装过程及配置
SourceTree 是一款拥有可视化界面的项目版本控制软件,适用于git项目管理,同时它集成了 git flow 工作流程,对于不熟悉 git 命令的初学者来说,可以通过 SourceTree 快速 ...
- 在sql中如何把一列的值拆分成多列
- jQuery-prepend、append、before、after的区别
举例说明,原始html代码如下: <ol> <li>List item 1</li> <li>List item 2</li> <li ...
- C语言中头文件怎么写?(本文来源网络,由黑乌鸦进一步完善)
c语言头文件怎么写?我一直有这样的疑问,但是也一直没去问问到底咋回事:所以今天一定要把它弄明白! 其实学会写头文件之后可以为我们省去不少事情,可以避免书写大量的重复代码.有利于整理思路.使代码脉络 ...
- CRUD全栈式编程架构之控制器的设计
页面 这里界面我采用jquery miniui来做的,当你完全了解了整个设计之后可以轻松切换到其他的js框架,个人认为类似muniui,easyui等等这类可以将web界面做得和winform类似的框 ...