JS--------(一)

目录

1.声明函数的方法

声明函数的方法
三种:函数的声明、函数表达式、Function 构造函数

  • (1)函数的声明
function print(s) {
  console.log(s);
}
  • (2)函数表达式

匿名函数赋值给变量。这时,这个匿名函数又称函数表达式,因为赋值语句的等号右侧只能放表达式。

采用函数表达式声明函数时,function命令后面不带有函数名。如果加上函数名,该函数名只在函数体内部有效,在函数体外部无效。

var print = function(s) {
  console.log(s);
};

var print = function x(){
  console.log(typeof x);
};

x;  // ReferenceError: x is not defined

print();  // function
  • (3)Function 构造函数

你可以传递任意数量的参数给Function构造函数,只有最后一个参数会被当做函数体,如果只有一个参数,该参数就是函数体。

var add = new Function(
  'x',
  'y',
  'return x + y'
);

// 等同于
function add(x, y) {
  return x + y;
}
  • 区别一:

函数声明会被提升,但是函数表达式不会被提升,因为函数表达式还没有被赋值,只是一个未定义变量,当然无法被执行。

        function a() {
            console.log('函数声明');
        }
        var b;
        a();
        b();  // TypeError: b is not a function
        b;    // 正确
        b = function () {
            console.log('函数表达式');
        }
  • 区别二:

函数表达式可以直接加圆括号就可以执行,而函数声明不行;

   var print = function (s) {
          console.log(s);
     }(10);  // 10

  function (s) {
            console.log(s);
        }(10);  // SyntaxError: function statement requires a name
  • 立即执行函数表达式的两种表现:
// 功能上是一致的,如何写凭个人喜好function() {})()function() {} ()); 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值