js立即执行函数原理

函数声明方式

function fn () { // 函数声明
    // ...
}
let fn = function () { // 函数引用
    // ...
}

function () { // 匿名函数
    // ...
}

(function () { // 立即执行函数
   // ...
}())

复制代码


此处讲的是立即执行函数的原理,所谓立即执行函数是被定义的时候就立即执行,而在Javascript中能立即被执行的只有表达式,普通函数被定义不会立即执行,等待被调用,而加上数学运算符 () 括号之后,会将函数声明转换成表达式,使函数能够被直接执行,并且执行后函数的执行上下文被销毁。


函数不仅能够被括号转换成表达式,还能够被其他一些数学运算符转换成表达式,从而能够被立即执行

!function () {
    console.log('立即执行')
}()
// print: '立即执行'

+function () {
    console.log('立即执行')
}()
// print: '立即执行'

-function () {
    console.log('立即执行')
}()
// print: '立即执行'

+function () {
    console.log('立即执行')
}()
// print: '立即执行'

~function () {
    console.log('立即执行')
}()
// print: '立即执行'复制代码


值得一提的是,立即执行函数之后,其他变量引用不到该函数,因为引用的是表达式返回的结果

var fn = (function () {  console.log('立即执行')}())
print'立即执行'
console.log(fn) // undefined


var fn = !function () {  console.log('立即执行')}()

print'立即执行'
console.log(fn) // true

复制代码


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值