夺命雷公狗---javascript NO:32 Call/Apply方法

行内绑定中this指向:全局window对象

动态绑定中this指向:当前要操作的dom对象

构造器中的this指向:谁实例化构造器那么其内部的this就指向谁

1、为什么需要Call与Apply方法

问题:我们可以不可以手工改变函数内部的this指向?答:可以,使用Call或Apply方法

2、如何定义Call与Apply方法

call([thisObj[,arg1[,arg2[,argN]]]])

参数说明:

函数.call(thisObj,arg1,arg2,arg3…)

thisObj :要指向的Obj对象

arg1,arg2,arg3 :要传递的参数

apply([thisObj[,argArray]])

参数说明:

thisObj :要指向的Obj对象

argArray :要传递的参数,要求格式为数组

Call与Apply方法区别?

在功能上,两者效果完全一致,都是用于改变函数内部的this指向

在语法上,两者语法略有不同

3、为对象添加一个speak成员方法

<!DOCTYPE html>
<html>
<head>
<meta charset=’utf-8′>
<title></title>
</head>
<body>
<script>
//定义一个公用的说话方法
function speak(){
alert(this.name+this.age);
}
function person(){}
//通过person构造器创建对象
var p1 = new person();
p1.name = ‘zhangsan‘;
p1.age = ’22′;
//通过call方法调用speak方法
speak.call(p1);
var p2 = new person();
p2.name = ‘lisi‘;
p2.age = ’55′;
//通过apply方法调用speak说话方法
speak.apply(p2);
</script>
</body>
</html>

4、call与apply方法执行流程

1)改变函数内部的this指向

2)调用函数

5、实现为speak方法传参

<!DOCTYPE html>
<html>
<head>
<meta charset=’utf-8′>
<title></title>
</head>
<body>
<script>
//定义一个公用的说话方法
function speak(email,address){
alert(this.name+this.age+email+address);
}
function person(){}
//通过person构造器创建对象
var p1 = new person();
p1.name = ‘zhangsan‘;
p1.age = ’22′;
//通过call方法调用speak方法
speak.call(p1,’[email protected]’,’广东省广州市’);
var p2 = new person();
p2.name = ‘lisi‘;
p2.age = ’55′;
//通过apply方法调用speak说话方法
speak.apply(p2,[‘5566@qq.com’,’广东省深圳市’]);
</script>
</body>
</html>

6、案例:同时改变文字大小与颜色特效

<!DOCTYPE html>
<html>
<head>
<meta charset=’utf-8′>
<title></title>
<script>
function fn1(){
this.style.color = ‘red‘;
}
function fn2(){
this.style.fontSize = ’30px‘;
}
window.onload = function(){
document.getElementById(‘result’).onclick = function(){
fn1.call(this);
fn2.apply(this);
}
}
</script>
</head>
<body>
<div id=’result’>call与apply方法主要功能是改变函数内部的this指向</div>
</body>
</html>
时间: 2024-10-05 05:39:35

夺命雷公狗---javascript NO:32 Call/Apply方法的相关文章

夺命雷公狗---javascript NO:30 闭包

1.什么是闭包 所谓“闭包”,指的是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分. 例1:运行一下代码,得出结论:在全局作用域没有办法直接引用局部变量 <!DOCTYPE html> <html> <head> <meta charset=’utf-8′> <title></title> </head> <body> <script> funct

夺命雷公狗---javascript NO:23 JavaScript中的this指针

1.自定义类中的this指针 在php中,我们在自定义类时,属性都是预定义在我们的自定义类中,而在JavaScript代码中,所有对象的属性和方法都是动态添加到对象中,那么可不可以让我们的自定义对象自动拥有类的属性和方法? 答:可以,通过this指针 例1:谁实例化自定义类,那么类中的this就指向谁 <!DOCTYPE html> <html> <head> <meta charset=’utf-8′> <title></title>

夺命雷公狗---javascript NO:31 私有属性

1.什么是私有属性 在JavaScript代码中,是没有public/protected/private等定义属性的关键词,但是我们可以通过模拟的方式来实现这个过程. 在JavaScript只有两种属性: 一种共有属性 一种私有属性 2.定义私有属性 在构造器内部,通过this定义的属性就是公有属性 在构造器内部,通过var定义的属性就是私有属性 <!DOCTYPE html> <html> <head> <meta charset=’utf-8′> <

夺命雷公狗---javascript NO:28 原型链

1.原型对象 在JavaScript中,每个构造器在加载后都会自动生成一个对象,我们把这个对象就称之为原型对象. 2.构造器与原型对象的关系 Person构造器与Person原型对象在内存中表现为相互独立,互不影响.但是在Person构造器中存在一个prototype属性指向Person原型对象,同时在Person原型对象中也存在一个属性指向Person构造器. 3.原型对象的作用 当我们在Person构造器的实例对象中引用一个不存在的属性或方法,系统会自动到Person构造器的原型对象中去寻找

夺命雷公狗---javascript NO:21 自定义类1

1.快速入门 例1:通过原生js与面向对象js定义一个人的信息 <!DOCTYPE html> <html> <head> <meta charset=’utf-8′> <title></title> </head> <body> <script> //通过js代码定义一个人的信息 var name = ‘lisi'; var age = ’30′; var marry = false; alert

夺命雷公狗---javascript NO:16 默认行为1

1.什么是默认行为 在我们的HTML标签中,很多标签拥有自己的默认行为. 如: submit提交按钮:其会自动提交表单数据到处理页面 a标签:其会自动跳转到指定页面 有些情况下,我们并不需要这种默认行为. 如: 当我们未填写表单数据时,系统不应该直接提交表单数据到处理页面. 当我们单击删除链接时,如果用户没有确认是不应该直接跳转删除的. 2.组织默认行为 IE模型浏览器 window.event.returnValue = false; W3C模型浏览器 dom对象.事件 = function(

夺命雷公狗---javascript NO:17 默认行为2

解决兼容性问题 ① 在public.js中创建prevent函数 ② 判断浏览器类型 ③ 编写一下程序代码 //解决阻止默认行为兼容性问题 function prevent(event){ if(window.event){ //IE模型浏览器 window.event.returnValue = false; }else{ //w3c event.preventDefault(); } } ④ 在html页面测试prevent方法 <!DOCTYPE html> <html> &

夺命雷公狗---javascript NO:15 事件冒泡3

解决事件冒泡兼容性问题 ① 在public.js函数库中创建stopBubble函数 ② 判断浏览器类型 //冒泡兼容性问题 function stopBubble(event){ if(window.event){ //IE window.event.cancelBubble = true; }else{ event.stopPropagation(); } } ③ 在html页面测试stopBubble函数 <!DOCTYPE html> <html> <head>

夺命雷公狗---javascript NO:27 通过json调用12306查询车次信息

出发地:广州 目的地:北京 查询 收费接口:数据聚合 http://www.juhe.cn/ 注册账号,申请12306接口 进入控制应用里面里面有一个 应用名称:  12306API 调用数据:   12306火车票查询 appkey:  XXXXXXXXXXXXXXXXX(因为这里是收费的) 应用包: 接口文档:(可以点击进入里面进行查阅接口该如何设置的) 网站左方有一个4.12306订票①:查询车次 里面有详细的传参方式 定义查询页面 示例: <!DOCTYPE html> <htm