在JavaScript中方法由两部分组成: 方法名方法体。 JavaScript中的方法跟其他传统面向对象语言不同,它跟普通的变量没有区别,唯一不同点是它是Function对象,因此它会有一些Function类的属性及方法。

方法的定义

  1. 声明式 *使用声明的方式定义的方法会在程序的预执行阶段进行解析,因此该定义可以放在程序中的任何地方,都会被正确加载, 执行。
  2. 叙述式 使用叙述式定义的方法必须当他们被执行后才能被调用。
  3. 构造方法 通过构造方法定义的方法,因调用的时候,总是解析方法体字符串,因此效率低,不推荐使用。
  4. eval 通过元编程定义方法
// 声明式
square(4); //可以执行,结果为16
function square(number) {
    return number * number;
}
// 叙述式
var square = function(number) {return number * number;};
square(4); //16

通过叙述式定义方法时,可以指定方法的名称,该方法名只能在方法内部进行调用

// 叙述式, 指定范围内的函数名称
// factorial为函数变量, fac为范围内的函数名称,只能在内部进行使用。
var factorial = function fac(n) { return n<2 ? 1 : n*fac(n-1) };
factorial(10); //3628800
fac(5); //ReferenceError: fac is not defined
// 构造方法
var sum = new Function("num1", "num2", "return num1 + num2;");
sum(4,5); //9
// eval
eval('function sum(num1, num2) {return num1 + num2;}');
sum(4,5); //9

方法的调用

  1. 方法名称
  2. arguments.callee 在 ES5 strict模式中禁止被使用
  3. 作用范围内的变量 //上例中的fac

闭包

简单来说闭包是方法内再一次定义方法,内部方法可以访问到外部方法的任何变量,并且在内部方法中使用到的变量的生命周期比外部方法长一些。

var pet = function(name) {   // 外部方法定义 name 变量
  var getName = function() {
    return name;             // 内部方法使用了外部方法的 name 变量
  }
  return getName;            // 返回内部方法,结果在外界可以调用到内部方法。
},
myPet = pet("Vivie");

myPet();  // Vivie
function outside(x) {
  function inside(y) {
    return x + y;
  }
  return inside;
}
fn_inside = outside(3);  // 调用了外部方法,传递的x为3,并且返回内部方法
result = fn_inside(5);   // 调用内部方法,传递y为5, 但因之前传递的x还存在,结果为8

result1 = outside(3)(5); // 8

方法内部 arguments 对象

  1. arguments 是像数组的一个对象,它有length方法,返回参数个数,也可以像数组,使用下标进行访问。
  2. arguments.callee 方法本身 已废弃
  3. arguments.callee.caller 调用的函数
function a() {
    console.log("a function run");
    console.log(arguments.callee.caller);      // null
    b();
}
function b() {
    console.log("b function run");
    console.log(typeof arguments.callee.caller);      // a函数
}
a();
// 像数组一样使用arguments
var args = [].join.call(arguments, ':');
// arguments转换为数组
var args = [].slice.call(arguments)

属性

  1. Function.length 参数个数
  2. Function.prototype 方法原型
  3. Function.arguments: 废弃,注意与 arguments对象 的区别
  4. Function.caller: 非标准
  5. Function.displayName: 非标准
  6. Function.name: 无法在产品模式中使用

方法

  1. Function.prototype.apply() 在指定的上下文对象和参数下调用方法,立即生效,参数为(context, args[])
  2. Function.prototype.call() 在指定的上下文对象和参数下调用方法,立即生效,参数为(context, args1[,args2[,args3]])
  3. Function.prototype.bind() 绑定指定参数的方法到指定的对象,需要时再进行调用。参数为(context, args1[,args2[,args3]])
  4. Function.prototype.toString() 生成对象的源代码
  5. Function.prototype.isGenerator() 非标准
  6. Function.prototype.toSource() 非标准
// apply
var a = {x:"AAA"};
function test() {
    var result = "";
    result += this.x;
    for(var i=0; i<arguments.length; i++) {
        result += arguments[i];
    }
    console.log(result);
}
test.apply(a, [1,2,3,4]); // AAA1234
// call
var a = {x:"AAA"};
function test() {
    var result = "";
    result += this.x;
    for(var i=0; i<arguments.length; i++) {
        result += arguments[i];
    }
    console.log(result);
}
test.call(a, 1,2,3,4); // AAA1234
// bind
var a = {x:"AAA"};
function test() {
    var result = "";
    result += this.x;
    for(var i=0; i<arguments.length; i++) {
        result += arguments[i];
    }
    console.log(result);
}
var bindFunc = test.bind(a, 1,2,3,4);
bindFunc(); // AAA1234

ES6 特性 了解就行

  • 参数 Default
function multiply(a, b = 1) {
  return a*b;
}

multiply(5); // 5
  • 参数 Rest
function multiply(multiplier, ...theArgs) {
  return theArgs.map(x => multiplier * x);
}

var arr = multiply(2, 1, 2, 3);
console.log(arr); // [2, 4, 6]
  • 箭头方法
var a = [
  "Hydrogen",
  "Helium",
  "Lithium",
  "Beryl­lium"
];

var a2 = a.map(function(s){ return s.length });  // [8, 6, 7, 10]
var a3 = a.map( s => s.length );                 // [8, 6, 7, 10]

参考资料

MDN
MDN Reference
JavaScript Info: Function expressions
JavaScript Info: Function arguments

JavaScript笔记 Function的更多相关文章

  1. [Effective JavaScript 笔记] 第5条:避免对混合类型使用==运算符

    “1.0e0”=={valueOf:function(){return true;}} 是值是多少? 这两个完全不同的值使用==运算符是相等的.为什么呢?请看<[Effective JavaSc ...

  2. [Effective JavaScript 笔记]第3章:使用函数--个人总结

    前言 这一章把平时会用到,但不会深究的知识点,分开细化地讲解了.里面很多内容在高3等基础内容里,也有很多讲到.但由于本身书籍的篇幅较大,很容易忽视对应的小知识点.这章里的许多小提示都很有帮助,特别是在 ...

  3. [Effective JavaScript 笔记]第27条:使用闭包而不是字符串来封装代码

    函数是一种将代码作为数据结构存储的便利方式,代码之后可以被执行.这使得富有表现力的高阶函数抽象如map和forEach成为可能.它也是js异步I/O方法的核心.与此同时,也可以将代码表示为字符串的形式 ...

  4. [Effective JavaScript 笔记]第28条:不要信赖函数对象的toString方法

    js函数有一个非凡的特性,即将其源代码重现为字符串的能力. (function(x){ return x+1 }).toString();//"function (x){ return x+ ...

  5. (转)深入理解javascript的function

    原文:http://www.cnblogs.com/sharpxiajun/archive/2011/09/16/2179323.html javascript笔记:深入理解javascript的fu ...

  6. 【原】javascript笔记之Array方法forEach&map&filter&some&every&reduce&reduceRight

    做前端有多年了,看过不少技术文章,学了新的技术,但更新迭代快的大前端,庞大的知识库,很多学过就忘记了,特别在项目紧急的条件下,哪怕心中隐隐约约有学过一个方法,但会下意识的使用旧的方法去解决,多年前ES ...

  7. javaScript笔记详解(1)

    javaScript基础详解 版权声明 本文原创作者:雨点的名字 作者博客地址:https://home.cnblogs.com/u/qdhxhz/ 首先讲javaScript的摆放位置:<sc ...

  8. JavaScript笔记(第一章,第二章)

    JavaScript笔记(第一章,第二章) 第一章: <meta http-equiv="Content-Type" content="text/html; cha ...

  9. [Effective JavaScript 笔记] 第4条:原始类型优于封闭对象

    js有5种原始值类型:布尔值.数字.字符串.null和undefined. 用typeof检测一下: typeof true; //"boolean" typeof 2; //&q ...

随机推荐

  1. 【iCore3应用开发平台】发布 iCore3 应用开发平台出厂代码rev0.0.5

    iCore3开发平台固件版本信息 =============================================================[stm32f407]:iCore3 ARM ...

  2. JavaScript + PHP 实现刷新继续保持倒计时的按钮

    场景:发送一个验证码到手机,当验证码发出时,会提示隔 1 分钟之后可以再次发送.通常有这几种方式防止恶意请求,一是再次发送之前需要输入验证码,二是在指定的时间间隔之内不能再次发送. 有些网站在 1 分 ...

  3. django 有model生成SQL以及现有反向表生成model

    已有models生成SQL语句 语法 python manage.py sqlall app_name   # app_name, 在settings已经导入, 如: INSTALLED_APPS = ...

  4. 神奇的VIM~转IBM

    % 地址范围符号,代表文件中的所有行,作用等同于地址范围 1,$ . 与任意单字符(换行符除外)匹配,例如 y.s 可以匹配 yas y.s 或 y s 等等. * 与前一字符的0次或多次出现匹配,例 ...

  5. Maven环境搭建

    1,下载maven zip版   http://maven.apache.org/download.cgi 2,配置maven环境变量 (1) 新建MAVEN_HOME环境变量  E:\TOOLS\A ...

  6. 手动删除portal中托管服务。

    在portal中将server作为托管联合服务器,然后发布了托管服务.若中间取消了托管联合服务器,再重新连接,那么会出现之前的托管服务无法删除的现象. 下文为怎样手动删除这些服务的方法,(不过貌似之后 ...

  7. Python 中的urlencode和urldecode

    python中的urlencode与urldecode 发表于2013/11/13 16:04:09  79983人阅读 分类: python 当url地址含有中文,或者参数有中文的时候,这个算是很正 ...

  8. Asp.Net Mvc Areas 的用法与好处

    前言 在项目中为什么要使用Areas 进行分离 大家都知道,一般的Web应用都有前台(面向用户)和后台(面向管理员)两部分,我们希望以/localhost/Admin 开始的Url 是用户的后台管理地 ...

  9. 关于sed用法

    sed处理流程 sed的处理流程,简化后是这样的: 1.读入新的一行内容到缓存空间: 2.从指定的操作指令中取出第一条指令,判断是否匹配pattern: 3.如果不匹配,则忽略后续的编辑命令,回到第2 ...

  10. Python学习之路【目录】

    本系列博文包含 Python基础.前端开发.Web框架.缓存以及队列等,希望可以给正在学习编程的童鞋提供一点帮助!!! 目录: Python学习[第一篇]python简介 Python学习[第二篇]p ...