45fan.com - 路饭网

搜索: 您的位置主页 > 电脑频道 > 编程代码 > 阅读资讯:JavaScript函数定义的详细教程

JavaScript函数定义的详细教程

2015-08-01 15:40:18 来源:www.45fan.com 【

JavaScript函数定义的详细教程

函数

几个要点:

a).函数是javascript中的一等公民 (重要性)
b).函数是一个对象
c).函数定义了一个独立的变量作用域

定义方式

a)命名函数:

除非在另一个函数内部定义,否则,命名函数是全局的。

   // 全局的命名函数
 function add(x, y) {
  return x + y;
 }
 console.info(add(100, 200)); //300

b)匿名函数:

匿名函数通常赋值给一个变量,再通过变量调用。

  var func = function (x, y) {
   return x + y;
  }
  console.info(func(5, 2)); //7

匿名函数适用于以下这种 “立即执行的匿名函数” 的情况:

  console.info(
   function (x, y) {
      return x + y;
     }(100, 200) //立即调用
    );

C)定义方式影响代码执行效果

命名函数可以先使用,再定义

  console.info(sum(10, 10));
  function sum(num1, num2) {
   return num1 + num2;
  }

匿名函数必须先定义,再使用

  //console.info(sumFunc(10, 10)); //Uncaught TypeError: Property 'sumFunc' of object [object Object] is not a function 
  var sumFunc = function (num1, num2) {
   return num1 + num2;
  };
  console.info(sumFunc(10, 10));


函数返回值:

用return 生成返回值.如没有return ,则函数返回undefined

 function func() {
 }
 console.info(func()); //undefined
 function func2() {
  return; //空的返回语句
 }
 console.info(func2()); //undefined

return里藏着的坑:

 var func = function (x, y) {
  var sum = x + y;
  return {
   value : sum
  }
 }

这么写没有问题: 调用 func(5,5) 返回的是 Object {value: 10}

然而:

 var func = function (x, y) {
  var sum = x + y;
  return
  {
   value: sum
  };
 }
 console.info(func(5,5)); //undefined

return 后面跟着个回车换行的话,
调用 func(5,5) 显示的是 undefined
编辑器帮我们在return后加了个分号; 然而在这情况下并没有什么卵用。

函数即对象:

 function add(x, y) {
  return x + y;
 }
 console.info(add(100, 200)); //300
 var other = add; //other和add引用同一函数对象
 console.info(other(300, 400)); //700
 console.info(typeof other); //function
 console.info(add === other); //true

嵌套定义的函数:

在函数内部,可以定义另一个函数。

 function outerFunc(a, b) {
  function innerFunc(x) {
   return x * x;
  }
  return Math.sqrt(innerFunc(a) + innerFunc(b));
 }
 console.info(outerFunc(3, 4)); //5

访问外部变量:

内部函数可以访问外部的变量与参数。

 var globalStr = 'globalStr';
 function outerFunc2(argu) {
  var localVar = 100;
  function innerFunc2() {
   localVar++;
   console.info(argu + ":" + localVar + ":" + globalStr);
  }
  innerFunc2(); //hello:101:globalStr
 }
 outerFunc2("hello");

返回函数的函数:

因为函数是对象,所以可以作为返回值。

 function outerFunc(x) {
  var y = 100;
  return function innerFunc() {
   console.info(x + y);
  }
 }
 outerFunc(10)(); //110

以上所述就是本文的全部内容了,希望大家能够喜欢。


本文地址:http://www.45fan.com/bcdm/16438.html
Tags: 详细 JavaScript 函数
编辑:路饭网
推广内容
推荐阅读
热门推荐
推荐文章
关于我们 | 联系我们 | 友情链接 | 网站地图 | Sitemap | App | 返回顶部