var a=function()与var a=new function()的区别

本文首发于我的博客

某天跟小伙伴聊到three.js的时候所遇。

话不多说,当时抛给我的代码如下


var d = new function(){
   return new String('圆心')
}
console.log(d)

问我返回是什么。

而当时这个d第一反应就是返回这个

ƒ (){
   return new String('圆心')
}

因为只是输出d而不是d()。就认为它没有运行。

而事实返回的是

String {0: "圆", 1: "心", length: 2, [[PrimitiveValue]]: "圆心"}

出现这种错误想法的原因就是对new function这种匿名函数表达式的立即调用不熟悉

其中声明String对象的方式与这个效果无关,以后再说

那么今天就趁机查漏补缺一下


我们平时写立即执行函数几乎都是

(function(){
  //something
})()

(function(){
  //something
}())


var f = function() {}();

//这种可能比较少,但也是可以运行的
[function(){
  //something
}()];

而有些情况下也会更炫酷的利用一些一元运算符来告诉解析器来直接执行

~ function() {}();  //我个人比较喜欢这种= =
! function() {}();
+ function() {}();
- function() {}();

上面文中的是这种

new function() {};

而其实下面这些也都是可以直接执行的

delete function() {}();
typeof function() {}();
void function() {}();
new function() {}();

1, function() {}();
1 ^ function() {}();
1 > function() {}();

说了这么多,用是都能拿来用了,但是他们有个共同点不知道你们发现没有。

就是所有能立即执行的函数,前面都会有其他东西,而不是直接function(){}()这种样子。

那是因为如果直接以function`开头。这算是函数声明。而函数声明是必须有标识符做为函数名称的。也就是必须要有函数名

那按照这个说法,,是不是function g(){}(),这样就可以了呢?

No、No、No。这种写法function g(){}是对的,声明了一个函数g,但是函数声明末尾是不能跟()的。这样()会被当做括号运算符执行。

代码执行如下

function g(){
  console.log("111")
}()
// Uncaught SyntaxError: Unexpected token )


function g(){
console.log("111")
}(1132141)

// 1132141

其实这里面还有可以深挖的,只是目前水平有限,业务为重,秉着28原理以后理解更深刻了再行挖掘

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,267评论 0 4
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,860评论 18 139
  • 前言 人生苦多,快来 Kotlin ,快速学习Kotlin! 什么是Kotlin? Kotlin 是种静态类型编程...
    任半生嚣狂阅读 26,259评论 9 118
  • 很喜欢去乡镇上的菜市场或者是火车站,因为可以看到形形色色的人,听到各种各样的谈话,这样真的很生活。当然,这...
    要吃葡萄阅读 284评论 0 0
  • 似水流年。花开花落,我们站在岁月的河边,开流水轻轻滑过,河面上是落英缤纷,以及逝去的年华。 职烨就是这样站着,水中...
    dca12c422815阅读 407评论 0 3