zoukankan      html  css  js  c++  java
  • Javascript学习笔记:3种定义函数的方式

    ①使用函数声明语法定义函数

    1 function sum(num1,num2){
    2   return num1+num2;  
    3 }

    ②使用函数表达式定义函数

    1 var sum=function(num1,num2){
    2   return num1+num2;  
    3 }

    ③使用Function构造函数定义函数

    1 var sum=new Function('num1','num2','return num1+num2');

    三种定义函数的方式,其中第二和第三种从技术角度讲都属于函数表达式的方式,但是不推荐使用第三种即使用Function构造函数的方式,因为这种方式性能低于前两种方式。不管以哪种方式定义函数,函数都是Function类型的实例,而且都与其他引用类型一样拥有属性和方法。这三种定义函数的方式唯一不等价的地方是:第二种和第三种方式定义的函数不存在函数声明提升,第一种方式定义的函数存在函数声明提升(所谓函数声明提升,也就是解析器在向执行环境中加载数据时,会率先读取函数声明,并使其在任何代码之前可以访问),其他方面都是等价的。

    1 sum(1,2);//3
    2 
    3 function sum(num1,num2){
    4  return num1+num2;
    5 }

    使用函数声明语法定义函数的方式存在函数声明提升,所以sum函数可以正常执行。

    1 sum(1,2);//TypeError: sum is not a function
    2 
    3 var sum=function(num1,num2){
    4   return num1+num2;  
    5 }

     使用函数表达式定义行数的方式不存在函数声明提升,所以会报出异常。

    1 sum(1,2);//TypeError:sum is not a function
    2 
    3 var sum=new Function('num1','num2','return num1+num2');

    使用Function构造函数定义函数的方式不存在函数声明提升,所以会报出异常。

  • 相关阅读:
    EditPlus保存文件时不生成其备份文件的方法
    一台电脑同时运行多个tomcat配置方法
    Dom4j写XML
    .....
    编程备忘录
    背包问题
    chrome新版不再支持-webkit-text-size-adjust
    安装grunt需要的grunt插件
    初学web前端
    心情烦躁、、
  • 原文地址:https://www.cnblogs.com/PolarisSky/p/5270185.html
Copyright © 2011-2022 走看看