JavaScript 函数调用的四种方式详解

需积分: 9 3 下载量 94 浏览量 更新于2024-09-09 收藏 5KB TXT 举报
"JavaScript函数调用的四种方式详解" 在JavaScript中,函数是第一类对象,可以被赋值给变量、作为参数传递、也可以作为返回值。因此,有多种方式来调用一个函数,每种方式都有其特定的用途和上下文。下面将详细介绍标题和描述中提到的四种函数调用方式。 1. **通过函数名直接调用** 这是最常见的方式,当函数不作为对象的属性时,可以直接通过函数名来调用它。例如: ```javascript function myFunction() { // 函数体 } myFunction(); // 直接调用函数 ``` 在这种情况下,`this`关键字的值取决于函数调用的上下文。在全局作用域中,`this`通常指向全局对象(在浏览器环境中是`window`)。 2. **通过对象的属性调用** 如果函数是某个对象的属性,可以通过对象实例来调用该函数,此时函数被称为方法。例如: ```javascript var myObject = { firstName: "John", lastName: "Doe", fullName: function() { return this.firstName + " " + this.lastName; } }; myObject.fullName(); // "John Doe" ``` 在这个例子中,`this`在`fullName`函数内部指向`myObject`,因为函数是通过`myObject`调用的。 3. **通过构造函数调用** 构造函数用于创建新对象,通过`new`关键字来调用。例如: ```javascript function Person(firstName, lastName) { this.firstName = firstName; this.lastName = lastName; } var x = new Person("John", "Doe"); x.firstName; // "John" ``` 当使用`new`关键字调用函数时,会创建一个新的对象,并将其绑定到`this`。函数体内的代码会在这个新对象上执行,返回的新对象通常是构造函数的结果。 4. **通过函数上下文(函数作用域)调用** 函数的上下文可以由`call()`和`apply()`这两个内置方法改变。它们允许我们显式地设置`this`的值,并传递参数。例如: ```javascript function multiply(a, b) { return a * b; } var myObject = { multiplier: 10 }; multiply.call(myObject, 5, 2); // 10 * 5 * 2 = 100 // 或者使用apply var myArray = [5, 2]; multiply.apply(myObject, myArray); // 同样的结果,数组元素作为参数传递 ``` 在上述例子中,`call()`和`apply()`都改变了`multiply`函数的上下文,使得`this`指向`myObject`。`call()`接受一个参数列表,而`apply()`接受一个参数数组。 需要注意的是,JavaScript有两种模式:严格模式('use strict')和非严格模式。在严格模式下,如果函数不是在对象上下文中被调用(比如在全局作用域),`this`会被设为`undefined`。而在非严格模式下,`this`可能被设置为`null`或者全局对象。 理解这些函数调用方式是掌握JavaScript核心概念的关键,它们在编写复杂的应用程序时尤其重要。熟练运用这些技巧可以帮助开发者更好地控制代码的行为和上下文。
2008-02-20 上传
第1 章 JavaScript 基 础 1.1 关 于JavaScript 1.2 了 解JavaScript 1.3 World Wide Web 1.4 Web 应用程序结构 1.5 JavaScript 与VBScript 第2 章 JavaScript 与HTML 2.6 HTML 基 础 2.7 在HTML 文档中嵌入JavaScript 2.8 编写JavaScript 脚本 第3 章 JavaScript 基本语法 3.9 JavaScript 基本数据结构 3.10 JavaScript 运算符和表达式 3.11 JavaScript 控制结构和循环 第4 章 Window 窗口对象 4.12 Window 窗口对象的属性 4.13 Window 窗口对象的方法 4.14 创建和关闭窗口 第5 章 document 对 象 5.15 document 对象的属性 5.16 document 对象的方法 第6 章 文 本 对 象 6.17 文本对象属性 6.18 文本对象的方法 6.19 文本对象的事件 6.20 文本区域对象 第7 章 按 钮 对 象 7.21 button submit reset 对 象 7.22 复选框对象 7.23 Radio 对 象 第8 章 选择和隐藏对象 8.24 select 对 象 8.25 隐 含 对 象 第9 章 location 对 象 9.26 hash 属 性 9.27 Href 属 性 9.28 pathname 属 性 9.29 Protocol 属 性 第10 章 history 对 象 第11 章 layer 对 象 11.30 layer 属 性 11.31 layer 对象的方法 11.32 JavaScript 操作层 第12 章 字符串对象 12.33 转 义 字 符 12.34 字符串对象的属性 12.35 字符串对象的方法 第13 章 日期对象 13.36 时间对象的属性 13.37 时间对象的设置 第14 章 数 学 对 象 14.38 math 对象的属性 14.39 math 对象的方法 第15 章 数 组 对 象 15.40 数组对象的创建 15.41 数组对象的扩充 15.42 对象类数组 第16 章 样式单实例 16.43 样式单的实用 16.44 样式单的定义 16.45 样式单的使用 第17 章 实用小程序 17.46 导 言 17.47 状态栏滚动信息 17.48 计算用户来访次数 17.49 散布页面的星星 17.50 永在顶端的图片 第18 章 JavaScript 语言的扩展 18.51 ActiveX 通 信 18.52 调用插入件 第19 章 网上购物系统 19.53 示 例 特 性 19.54 源 代 码 19.55 功 能 概 述 19.56 程 序 详 解 第20 章 2000 珍藏版 20.57 Cookie 入 门 20.58 实 例 特 性 20.59 程序源代码 20.60 功 能 概 述 20.61 程 序 详 解 第21 章 时 钟 日 历 21.62 示 例 特 性 21.63 源 代 码 21.64 功 能 概 述 21.65 程 序 详 解 第22 章 JavaScript 服务器端编程 22.66 预 备 知 识 22.67 实 例 学 习 22.68 功 能 概 述 22.69 脚 本 详 解 第23 章 网络安全性 23.70 安全性破坏的种类 23.71 安 全 服 务