函数的自执行,变量提升和函数提升
2018-06-24 01:43:57来源:未知 阅读 ()
其实之前虽然刚开始学习JavaScript的时候经常看到function add(){}、var add=function(){}、function(){}之类的这种写法,但是具体是什么叫什么却没有去考虑过这个问题……
function add(){}这种写法叫做函数声明
var add=function(){}这种写法叫做函数表达式
function(){}这种是匿名函数
一、函数的自执行
那么有没有办法让它们不用通过我们的调用比如
function add(){}; add();
就可以自我执行呢?
我们来试试看这三种方法
//函数表达式自执行尝试 var add=function(x,y){ console.log(x+y); }(5,6); //结果:11(正确) ) //函数声明自执行尝试 function add(x,y){ console.log(x+y); }(5,6); //结果:无法执行,也没有抛出错误 //匿名函数自执行尝试 function(){ console.log(arguments[0]+arguments[1]); }(5,6); //结果:这个的问题就大了,抛出语法错误Uncaught SyntaxError: Unexpected token (
函数表达式后面加括号可以立即执行函数,然而函数声明却不可以!!
很奇怪地,匿名函数也是函数表达式,但是它为什么会抛出语法错误呢?这是因为匿名函数虽然属于函数表达式,但是很明显它没有赋值操作,JavaScript解析引擎会把它当做函数声明,会跟你要一个函数名,但是它是匿名函数,肯定没有名字,JavaScript混了,直接给你个错误让你反省一下。
那要怎么解决匿名函数自执行这个问题?其实很简单,只要告诉JavaScript解析器匿名函数不是函数声明就好了。
//加号 +function(){ console.log(arguments[0]+arguments[1]); }(5,6); //减号 -function(){ console.log(arguments[0]+arguments[1]); }(5,6); //感叹号 !function(){ console.log(arguments[0]+arguments[1]); }(5,6); //括号 (function(){ console.log(arguments[0]+arguments[1]); })(5,6); (function(){ console.log(arguments[0]+arguments[1]); }(5,6));
接下来就是解决函数声明自执行的问题了,其实方法跟匿名函数自执行的方法是一样的,加号,减号,感叹号,括号,都可以解决
!function add(x,y){ console.log(x+y); }(5,6); +function add(x,y){ console.log(x+y); }(5,6); -function add(x,y){ console.log(x+y); }(5,6); (function add(x,y){ console.log(x+y); })(5,6); (function add(x,y){ console.log(x+y); }(5,6));
二、变量提升、函数提升
函数声明才会提升,函数表达式是属于变量提升
我们先来看一下下面这段代码的结果是什么
console.log(a); console.log(b); console.log(c); var a=1; function b(){ return 2; } var c=function(){ return 3; }
结果
console.log(c)的结果跟console.log(a)是一样的,说明函数表达式是属于变量提升的。这样证明还是有点草率,我们再来看看下面的代码
console.log(b()); console.log(c()); function b(){ return 2; } var c=function(){ return 3; }
结果
结果很明显了,函数c只是提升了变量名c而已,函数声明才会提升!
那么变量的提升和函数声明的提升哪个提升的优先级比较高呢?
console.log(b); console.log(b()); var b=1; function b(){ return 2; }
结果
结果显示函数声明提升的优先级比变量提升还要高。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:入门Promise的正确姿势
- JavaScript函数表达式详解及实例 2020-03-25
- 带你了解JavaScript中的函数 2020-03-08
- 在JavaScript中尽可能使用局部变量的原因 2020-03-08
- 详谈构造函数加括号与不加括号的区别 2020-01-17
- Node.js中环境变量process.env的一些事详解 2020-01-17
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash