前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >第24天:js-函数变量声明提升

第24天:js-函数变量声明提升

作者头像
半指温柔乐
发布2018-09-11 11:48:40
1.8K0
发布2018-09-11 11:48:40
举报
文章被收录于专栏:前端知识分享

一、函数声明 1、自定义函数 function fun1(){ alert("我是自定义函数"); } fun2();//函数不调用,自己不执行 2、直接量声明 var fun2=function(){ alert("直接量声明"); } fun2(); 3、利用Function关键字声明 var fun3=new Function("var a=10;b=20;alert(a+b)"); fun3();

二、变量声明提升 如果在一个函数体内部声明了一个变量,不管这个变量函数外部有没有,先执行函数内部的变量,会将变量声明提升到函数开始部分,但是不会赋值。 在函数体内部声明变量,会把该声明提升到函数体的最顶端。但是只提升变量声明,不赋值。 var num=10; fun1(); function fun1(){ console.log(num); var num=20;//变量提升 }//undefined 相当于 var num=10; fun1(); function fun1(){ var num; console.log(num); num=20; }

三、函数传参

函数实参个数要与形参个数相同,arguments.length可以获取函数实参的个数

代码语言:javascript
复制
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <script>
 7         /*变量提升*/
 8         /*window.onload=function(){
 9             var num=10;
10             fun1();
11             function fun1(){
12                 console.log(num);
13                 var num=20;//变量提升
14             }
15         }//结果:undefined*/
16 
17         /*var a=18;
18         f1();
19         function f1(){
20             var b=9;
21             console.log(a);
22             console.log(b);
23             var a='123';
24         }//undefined,9
25         */
26         /*函数传参*/
27         /*function f1(a,b){
28             console.log(a+b);
29         }
30         f1(1,2);//3
31         f1(5);//NaN*/
32 
33         /*检测函数参数个数匹配*/
34         function fn(a,b){
35             console.log(fn.length);//获取函数形参的个数
36             console.log(arguments.length);//得到的是实参的个数
37             if(fn.length==arguments.length){
38                 console.log(a+b);
39             }else{
40                 console.log("对不起,您的参数不匹配,正确的参数个数为:"+fn.length);
41             }
42         }
43         fn(5,3);//2,2,8
44         fn(2,3,4)//2,3,"对不起..."
45 
46 
47     </script>
48 </head>
49 <body>
50 
51 </body>
52 </html>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-09-06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档