JavaScript中的this所引用的对象和如何改变这个引用
this是函数内部的一个特殊对象,它引用的是函数执行环境对象。也就是运行是基于函数的执行环境绑定。
1.在网页全局作用域中调用函数时,this引用window
var color='black';
function saycolor(){
console.log(this.color);
}
saycolor();//'black'
第5行函数saycolor在全局作用域调用时this引用的是全局对象window,所以this.color的值就是window.color的值。
2.作为某个对象的方法被调用时,this等于该对象。
var o={
color:'white',
saycolor:function(){
console.log(this.color);
}};
o.saycolor();//'white'
我们定义了一个新对象o,并为o添加了一个属性color和一个方法saycolor,第8行调用o对象的saycolor函数时,this引用的是对象o,所以this.color的值变成了o.color的值。
3.匿名函数的执行函数具有全局性,因此它的this通常指向window
var name='The Window'; var object={
name:'My Object', getName:function(){
return function(){
return this.name;
};
}
};
console.log(object.getName()());//'The Window'
object.getName()返回的是一个函数,因此object.getName()()会立即调用它返回的函数。内部函数在搜索this变量时,只会搜索到其活动对象为止,所以不可能直接访问外部函数的this变量,也就是this不可能引用object对象。
4.把外部函数的this对象保存在闭包可访问到的变量中,在闭包中就可访问该对象了
var name='The Window'; var object={
name:'My Object', getName:function(){
var that=this;
return function(){
return that.name;
};
}
}; console.log(object.getName());//'My Object'
在定义匿名函数之前,我们把this赋值给一个that变量,在定义闭包之后,闭包也可以访问这个变量,即使在函数返回之后,这个变量也引用着object对象,所以调用object.getnName()()返回'My Object'。
this是一个强大而又复杂的对象,我们一定要理解好它具体指代什么对象,接下来我们介绍两个方法call()和apply()。这两个方法的用途是在特定的作用域中调用函数,等于设置函数体内this对象的值。它们最强大的是能够扩大函数赖以运行的作用域。
call()与apply()只改变this对象的时候,只需要传入要引用的对象,此时它们作用相同,可以互用。它们扩充作用域的最大好处是方法与对象不需要任何耦合关系。
var color='black';
var o={color:'white'}; function saycolor(){
console.log(this.color);
}
saycolor(); //'black' saycolor.call(this);//'black'
saycolor.call(window);//'black'
saycolor.call(o);//'white'
saycolor.apply(this);//'black' saycolor.apply(o);//'white'
它们的区别是apply纯如的第二个参数是数组,call传入的第二组参数需要一个个列举出来。代码如下:
function sum(num1,num2){
return num1+num2;
} function applySum(num1,num2){
return sum.apply(this,arguments); /*参数第一个是在其中运行函数的作用域,第二个参数是数组 等价于 return sum.apply(this,[num1,num2]);*/
} function callSum(num1,num2){
return sum.call(this,num1,num2);/*参数第一个是在其中运行函数的作用域,后面一个个传参数*/
} console.log(applySum(10,10));//20
console.log(callSum(10,10));//20
另外还有一个方法bind(),这个方法会创建一个函数实例,它的this值会被绑定到传给传给bind()函数的值
var color='black';
var o={color:'white'}; function saycolor(){
console.log(this.color);
}
var objsaycolor=saycolor.bind(o);
objsaycolor();//'white'
saycolor调用bind()并传入对象o,创建了objsaycolor()函数,该函数的this值等于o,因此即使全局作用域中调用这个函数,也得到的是'white'。使用这个方法是根据是否需要object对象响应来决定的。
JavaScript中的this所引用的对象和如何改变这个引用的更多相关文章
- JavaScript中两种类型的全局对象/函数【转】
Snandy Stop, thinking is the essence of progress. JavaScript中两种类型的全局对象/函数 这里所说的JavaScript指浏览器环境中的包括宿 ...
- JS对象 JavaScript 中的所有事物都是对象,如:字符串、数值、数组、函数等,每个对象带有属性和方法。
什么是对象 JavaScript 中的所有事物都是对象,如:字符串.数值.数组.函数等,每个对象带有属性和方法. 对象的属性:反映该对象某些特定的性质的,如:字符串的长度.图像的长宽等: 对象的方法: ...
- JavaScript中的Function(函数)对象详解
JavaScript中的Function对象是函数,函数的用途分为3类: 作为普通逻辑代码容器: 作为对象方法: 作为构造函数. 1.作为普通逻辑代码容器 function multiply(x, y ...
- JavaScript中两种类型的全局对象/函数
这里所说的JavaScript指浏览器环境中的包括宿主环境在内的. 第一种是ECMAScript Global Object,第二种是宿主环境(Host)下的全局对象/函数. 一.核心JavaScri ...
- JavaScript中的Function(函数)对象
1.document.write(""); 输出语句 2.JS中的注释为// 3.传统的HTML文档顺序是:document->html->(head,body) 4. ...
- javascript中字符串格式转化成json对象记录
什么是JSON JSON(JavaScript Object Notation)是一种优美的JavaScript对象创建方法.JSON也是一种轻量级数据交换格式.JSON非常易于人阅读与编写,同时利于 ...
- JavaScript中Global、Math、Date对象的常用方法
JavaScript当中Global.Math.Date类型常用方法如下: /* js 中 Global对象 是一个不存在的对象,它里面的方法可以调用 常用方法: 1 encodeURI 对uri进行 ...
- Javascript中判断变量是数组还是对象(array还是object)
怎样判断一个JavaScript变量是array还是obiect? 答案: 1.如果你只是用typeof来检查该变量,不论是array还是object,都将返回‘objec'. 此问题的一个可行的答案 ...
- JavaScript中把Json字符串转化为对象
1.采用eval()函数 定义和用法 eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码. 语法 eval(string) 参数 描述 string 必需.要计算的字符串, ...
随机推荐
- $Django 路飞之显示视频,Redis存购物车数据,优惠卷生成表,优惠卷的一个领取表。(知识小回顾)
知识小回顾之json序列化问题 精髓:支持python的几种数据类型(注意不是对象,不能放对象),其次是tuple变list. ensure_ascii:默认值True,如果dict内含有non-AS ...
- webpack4 搭建遇到的奇葩问题集合
一.webpack4 打包es6 会报错 需要安装一下插件 https://blog.csdn.net/Beamon__/article/details/85048448二.webpack4 打包动态 ...
- 在js中插入html语句
连上数据库之后,填充数据时往往需要在js中插入html语句 做法是: <body> <div class="modal-body" id="delete ...
- HDU 2196 Compute --树形dp
Computer Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ...
- C++\CLI语法 在项目中的使用
通常情况下,对一个标准的com组件进行集成,网上普遍使用的方式有: 1.#import *.dll 或 #import *.ocx的方式,VS编译器重新编译后,就会自动生成组件对应的*.tlh文件,该 ...
- javascript模板引擎template.js使用
到GitHub上下载template.js库.引入到页面 以type="text/html" 这样指定javascript类型的是一种javascript模板渲染方法,在实际项目中 ...
- pyqt pyside 窗口自动调整大小
pyqt pyside 窗口自动调整大小 在QTimer中一直调整 def initTimer(self): self.resizeTimer = QtCore.QTimer(self) self.r ...
- POJ 1185 炮兵阵地 【状压DP】
<题目链接> 题目大意: 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平 ...
- YII2 用 in查询的时候出现无结果, 删除某些值后查询有结果 提前sort数组即可
YII2 用 in查询的时候出现无结果, 删除某些值后查询有结果, 在数组前用了一个 array_merge 合并了2个数组. 排查发现是 数组中键值没有挨着从0开始 另外没有从小到大, 没观察室哪个 ...
- [CQOI2015]网络吞吐量
Description: 给你一个图,每个点可以被经过\(a_i\)次,求有多少个人可以走最短路到n点 Hint: \(n \le 500\) Solution: 极其水的一道题,就当做复习最短路板子 ...