整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

JavaScript 对象调用其他成员和函数

JavaScript 对象调用其他成员和函数

象调用其他函数或其他对象成员

实例1:

<script type="text/javascript">
//对象调用其他函数-方法
function say(){
document.write('在演讲');
}
var cat={name:'kitty',age:3};
//使得cat对象去调用say函数(给cat丰富一个成员并赋予say引用即可)
cat.express=say;//引用传递
cat.express();//在演讲
</script>

实例2:

<script type="text/javascript">
//对象调用其他函数-方法
var addr="beijing";
function say(){
//this代表调用该函数的当前对象
document.write("在"+this.addr+'演讲');
}
say();//在beijing演讲
var dog={addr:'德国',color:'black'};
//dog去调用say函数
dog.wang=say;
dog.wang();//在德国演讲
</script>

实例3:

JavaScript 函数有 4 种调用方式。

每种方式的不同方式在于 this 的初始化。

this 关键字

一般而言,在Javascript中,this指向函数执行时的当前对象。

注意 this 是保留关键字,你不能修改 this 的值。

调用 JavaScript 函数

我们知道如何创建函数。

函数中的代码在函数被调用后执行。

作为一个函数调用

实例

function myFunction(a, b) {

return a * b;

}

myFunction(10, 2); // myFunction(10, 2) 返回 20

以上函数不属于任何对象。但是在 JavaScript 中它始终是默认的全局对象。

在 HTML 中默认的全局对象是 HTML 页面本身,所以函数是属于 HTML 页面。

在浏览器中的页面对象是浏览器窗口(window 对象)。以上函数会自动变为 window 对象的函数。

myFunction() 和 window.myFunction() 是一样的:

实例

function myFunction(a, b) {

return a * b;

}

window.myFunction(10, 2); // window.myFunction(10, 2) 返回 20

这是调用 JavaScript 函数常用的方法, 但不是良好的编程习惯 全局变量,方法或函数容易造成命名冲突的bug。

全局对象

当函数没有被自身的对象调用时, this 的值就会变成全局对象。

在 web 浏览器中全局对象是浏览器窗口(window 对象)。

该实例返回 this 的值是 window 对象:

实例

function myFunction() {

return this;

}

myFunction(); // 返回 window 对象

函数作为全局对象调用,会使 this 的值成为全局对象。使用 window 对象作为一个变量容易造成程序崩溃。

函数作为方法调用

在 JavaScript 中你可以将函数定义为对象的方法。

以下实例创建了一个对象 (myObject), 对象有两个属性 (firstNamelastName), 及一个方法 (fullName):

实例

var myObject={

firstName:"John",

lastName: "Doe",

fullName: function () {

return this.firstName + " " + this.lastName;

}

}

myObject.fullName(); // 返回 "John Doe"

fullName 方法是一个函数。函数属于对象。 myObject 是函数的所有者。

this对象,拥有 JavaScript 代码。实例中 this 的值为 myObject 对象。

测试以下!修改 fullName 方法并返回 this 值:

实例

var myObject={

firstName:"John",

lastName: "Doe",

fullName: function () {

return this;

}

}

myObject.fullName(); // 返回 [object Object] (所有者对象)

函数作为对象方法调用,会使得 this 的值成为对象本身。

使用构造函数调用函数

如果函数调用前使用了 new 关键字, 则是调用了构造函数。

这看起来就像创建了新的函数,但实际上 JavaScript 函数是重新创建的对象:

实例

// 构造函数:

function myFunction(arg1, arg2) {

this.firstName=arg1;

this.lastName=arg2;

}

// Thiscreates a new object

var x=new myFunction("John","Doe");

x.firstName; // 返回 "John"

构造函数的调用会创建一个新的对象。新对象会继承构造函数的属性和方法。

构造函数中 this 关键字没有任何的值。this 的值在函数调用时实例化对象(new object)时创建。

作为函数方法调用函数

在 JavaScript 中, 函数是对象。JavaScript 函数有它的属性和方法。

call()apply() 是预定义的函数方法。 两个方法可用于调用函数,两个方法的第一个参数必须是对象本身。

实例

function myFunction(a, b) {

return a * b;

}

myFunction.call(myObject, 10, 2); // 返回 20

实例

function myFunction(a, b) {

return a * b;

}

myArray=[10,2];

myFunction.apply(myObject, myArray); // 返回 20

两个方法都使用了对象本身作为第一个参数。 两者的区别在于第二个参数: apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入,而call则作为call的参数传入(从第二个参数开始)。

在 JavaScript 严格模式(strict mode)下, 在调用函数时第一个参数会成为 this 的值, 即使该参数不是一个对象。

在 JavaScript 非严格模式(non-strict mode)下, 如果第一个参数的值是 null 或 undefined, 它将使用全局对象替代。

通过 call() 或 apply() 方法你可以设置 this 的值, 且作为已存在对象的新方法调用。

如您还有不明白的可以在下面与我留言或是与我探讨QQ群308855039,我们一起飞!

JavaScript中,函数调用和上下文是理解语言核心机制的关键。本文将深入探讨函数调用、this关键字以及apply方法的使用。

首先,让我们回顾一下函数调用的基础。在JavaScript中,函数可以通过多种方式调用,包括常见的函数调用、方法调用和构造函数调用。例如,定义了一个简单的函数foo:

function foo(a, b, c) {

console.log("foo功能...");

console.log(a, b, c);

return 123;

}

接下来,我们使用对象字面量创建了一个对象p1,其中包含了属性name和age,以及两个方法eat和run:

var p1={ name: "yuan",

age: 22,

eat: function () {

console.log(this.name + " is eating");

},

run: foo, // 这里将函数foo作为方法赋值给run属性

};

在这个例子中,p1对象的run属性指向了之前定义的foo函数。然后,我们调用了eat和run方法:

p1.eat();

p1.run(1, 2, 3);

这时,我们深入研究了函数内部的this关键字。在对象方法中,this通常指向调用该方法的对象。但是,在JavaScript中,我们可以使用apply方法动态设置函数执行时的上下文。

var _foo=foo;

foo=function () {

console.log("截断开始...");

_foo.apply(this, arguments);

console.log("截断结束...");

};

在这个例子中,foo函数被重新定义,使用apply方法在函数执行前后输出信息。此时,this在_foo.apply(this, arguments)中指向了foo函数本身。

最后,我们遇到了一个关于eval函数的问题。在JavaScript中,eval允许执行传入的字符串作为JavaScript代码。然而,eval的使用需要谨慎,因为它可能引起安全性和性能方面的问题。

eval('console.log("hello")');

var _eval=eval;

eval=function (src) {

console.log("eval截断开始...");

_eval(src);

console.log("eval截断结束...");

};

eval("console.log('hello....')");

在这个例子中,我们重新定义了eval函数,通过截断的方式在函数执行前后输出信息。

通过这一系列例子,我们深入了解了JavaScript中函数调用、上下文和一些关键字的使用。函数是JavaScript中的核心概念之一,理解函数的调用方式和上下文有助于更有效地使用这门语言。