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 还没有执行的时候,就报错了,,,当然这得归因于函数声明语句声明提前(发生在代码执行之前)的原因 ...
随机推荐
- Hibernate系列3-----之修改
只是修改测试类,先看其他的代码的同学,请翻看我的博客Hibernate1,嘿嘿,我就在这不在重写一遍来 @Test public void testhibernate() { updateStuden ...
- iOS 8 提供 TestFlight 方便开发者测试软件 (转)
原文地址:http://tech2ipo.com/66893 TestFlight / via iMore 作者: Nick Arnott 译者:翛凌 原文:iMore iOS 应用程序的测试对 ...
- vueHistory 模式下,布置到服务器上路由刷新会报nginx404错误
之前写完vue项目后,布置到服务器,用nginx反向代理后,一开始进去,进各种路由都是没问题的,但是一旦f5刷新后就会出现一个nginx404的错误. 经过翻阅vue文档后,发现这是vueHistor ...
- 1.字符串池化(intern)机制及拓展学习
1.字符串intern机制 用了这么久的python,时刻和字符串打交道,直到遇到下面的情况: a = "hello" b = "hello" print(a ...
- sass文件转css时注释虽然支持中文,但是出现乱码的解决方法
sass文件转css时注释虽然支持中文,但是出现乱码的解决方法 Scss 注释中文报错问题(windows系统, 已解决)找到ruby的安装目录,里面也有sass模块,类似这样样的路径:F:\Prog ...
- android里的继承浅析
先看一段代码: abstract class A{ public A(){ this.print(); } public abstract void print(); } class B extend ...
- Tomcat启动报Error listenerStart错误 | "beans" 必须匹配 DOCTYPE 根 "null" | java.lang.reflect.MalformedParameterizedTypeException
maven打包发布工程时,发布上去却报错FAIL - Deployed application at context path /ch but context failed to start 在服务器 ...
- java:数据库操作JDBC
JDBC详解:https://www.cnblogs.com/erbing/p/5805727.html JDBC存储过程,事务管理,数据库连接池,jdbc的封装框架:https://www.cnbl ...
- JAVA去掉HTMl以及CSS样式
封装方法如下 public String delHTMLTag(String htmlStr){ String regEx_style="<style[^>]*?>[\\s ...
- IOS 设置颜色的的详情
- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...