象调用其他函数或其他对象成员
实例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), 对象有两个属性 (firstName 和 lastName), 及一个方法 (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中的核心概念之一,理解函数的调用方式和上下文有助于更有效地使用这门语言。
*请认真填写需求信息,我们会在24小时内与您取得联系。