JS中----this的指向和如何修改this的指向
this
this是js中的一个关键字,函数运行时自动生成的一个内部对象,只能在函数内部使用。我们要讨论的是 this 的指向。
this就是函数运行时自动生成的一个内部对象
下面介绍一下几种情况下,this的指向
1、全局环境
全局环境下,this就代表window对象。(针对web 应用来讲)
var name = 'zhar';
function say(){
console.log(this.name);//zhar
}
say();
同样,在 setTimeout 或 setInterval 这样的延时函数中调用也属于全局对象。
var name = 'zhar';
setTimeout(function(){
console.log(this.name);//zhar
},0);
2、对象环境
对象环境指向对象。
var obj = {
name : "zhar",
say : function(){
console.log(this.name);//zhar
}
}
obj.say();
下面举两个经典的例子:
var name = 'tom';
var obj = {
name : "zhar",
say : function(){
console.log(this.name);
}
}
var fun = obj.say;
fun();//输出 ?//tom-->fun定义在全局环境下,即window.fun()
//再次说明了this的指向是由运行时的执行环境来决定的
var name = 'tom';
var obj = {
name : "zhar",
say : function(){
return function(){
console.log(this.name);
}
}
}
obj.say()();//输出 ?//tom
3、构造函数环境
构造函数中的this 会指向创建出来的实例对象,使用new 调用构造函数时,会先创建出一个空对象,然后用call函数把构造函数中的this指针修改为指向这个空对象。执行完环境后,空对象也就有了相关的属性,然后将对象返回出去,所以说就不用我们自己手动返回啦~
function Person() {
this.name = 'zhar';
}
var p = new Person();
console.log(p.name);
综合以上,构造函数不需要返回值,如果我们指定一个返回值时,this的指向将发生变化
function Person() {
this.name = 'zhar';
return {};
}
var p = new Person();
console.log(p.name);//undefined
//--------------------------------------
function Person() {
this.name = 'zhar';
return {name:'tom'};
}
var p = new Person();
console.log(p.name);//tom 如果构造函数返回对象(Object,Array,Function),那 this 将指向这个对象,其它基础类型则不受影响
//--------------------------------------
function Person() {
this.name = 'zhar';
return 1;//number string boolean 等
}
var p = new Person();
console.log(p.name);//zhar
所以,如无必要我们通常不要设置构造函数的返回值
4、事件对象
在 DOM 事件中使用 this,this 指向了触发事件的 DOM 元素本身
li.onclick = function(){
console.log(this.innerHTML);
}
总结下来就是一句话:是谁调用的,this就指向谁
下面介绍一下如何来修改this 的指向
1、可以使用局部变量来代替this指针
var name = "zhar";
var obj = {
name : "zhar",
say : function(){
var _this = this;//使用一个变量指向 this
setTimeout(function(){
console.log(_this.name);
},0);
}
}
obj.say();
该方法为非常常用的一个方法
2、使用call 或 apply 方法
首先说明一下,call也是函数调用的一种形式,可以通过 函数名.call()来调用函数。但是提供了一个修改this指向的方法。
fun.call(thisObj[,arg1[,arg2[,...]]])
调用方式和传入参数如上面的形式。其中,所以call(thisObj[,arg1[,arg2[,...]]])中的第一个参数就是要更改this指向的对象,为必选参数; 之后的参数要根据调用的函数是否需要传入参数(为可选的)
下面通过代码来展示call 如何使用:
var name = 'zhar';
function say(){
console.log(this.name);
};
say();//zhar;
var obj = {
name : 'tom',
say : function(){
console.log(this.name);
}
}
say.call(obj);//tom 将 say 函数中的 this 替换为传入的对象
obj.say();//tom
obj.say.call(null);//zhar 将 obj.say 函数的 this 替换为了 null,也就意味着指向了全局环境
//前面课程的继承代码
function Person(){
this.name = "人";
}
function Student(){
Person.call(this,null);
}
var s = new Student();
console.log(s.name);
li.onclick = function(){
console.log(this.innerHTML);//此处的 this 代表着 DOM 元素
function update(){
this.innerHTML += " new ";
}
//update();//这样做的话,this 的指向将变为window
update.call(this);//通过 call 方法修改函数内 this 的指向
}
//call 的传参
function say(arg1,arg2){
console.log(this.name,arg1,arg2);
};
var obj = {
name : 'tom',
say : function(){
console.log(this.name);
}
}
say.call(obj,'one','two');//tom one two
apply
apply的作用和call一样,不同的是传参的形式。apply需要以数组的形式传递参数
//apply 的传参
function say(arg1,arg2){
console.log(this.name,arg1,arg2);
};
var obj = {
name : 'tom',
say : function(){
console.log(this.name);
}
}
say.apply(obj,['one','two']);//tom one two
以上就是关于this指向和如何修改this指向的介绍
JS中----this的指向和如何修改this的指向的更多相关文章
- JS中OOP之模拟封装和继承和this指向详解
大家好,今天我带大家学习一下js的OOP, 大家都知道,面向对象有三个基本特征,继承,封装和多态,面向对象的语言有那么几种,C++,PHP,JAVA等,而功能强大的JS可以模拟实现面向对象的两大特征, ...
- js中的几种继承方法
JS作为面向对象的弱类型语言,继承也是其非常强大的特性之一. 继承:子承父业:一个原本没有某些方法或属性的对象,统一写方法,拿到了另外一个对象的属性和方法 下面是js中的几种继承方式 1.改变this ...
- js中修改this指向的方法(call,apply,bind)
前言:call.apply和bind都是为了改变某个函数运行时的this指向的,对于前端人员来说,关于this的掌握程度,直接决定了前端水平的高低.下面我们就来简单浅显易懂的来看一下es5中常用的三种 ...
- 关于js中this指向的理解总结!
关于js中this指向的理解! this是什么?定义:this是包含它的函数作为方法被调用时所属的对象. 首先,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁 ...
- js 中this到底指向哪里?
其实js的this指向很简单.我们记住下面3种情况. this 指向的是浏览器中的window.代码如下: function fn(){ this.name='yangkun'; this.age=2 ...
- js中this绑定方式及如何改变this指向
this的绑定方式基本有以下几种: 隐式绑定 显式绑定 new 绑定 window 绑定 箭头函数绑定 隐式绑定 第一个也是最常见的规则称为 隐式绑定. var a = { str: 'hello', ...
- JS中this指向的更改
JS中this指向的更改 JavaScript 中 this 的指向问题 前面已经总结过,但在实际开中, 很多场景都需要改变 this 的指向. 现在我们讨论更改 this 指向的问题. call更改 ...
- js中this指向的问题与联系
前言 JavaScript 中最大的一个安全问题,也是最令人困惑的一个问题,就是在某些情况下this的值是如何确定的.有js基础的同学面对这个问题基本可以想到:this的指向和函数调用的方式相关.这当 ...
- 彻底理解js中this的指向,不必硬背。
首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问题,虽然 ...
随机推荐
- react踩坑记录——使用fetch获取json数据报错
报错: 原因其实是list.json文件路径错误,该文件路径是相对于index.html的,而不是App.js或者index.js.
- require/exports 与 import/export 的区别?
文章作者:寸志链接:https://www.zhihu.com/question/56820346/answer/150724784来源:知乎 遵循的模块化规范不一样 模块化规范:即为 JavaScr ...
- 《前端福音,vue.js 之豆瓣电影组件大揭秘-video》
{{ message }} 小胡子语法 在 Vue 中被称之为双花括号插值表达式 ---------------- http://todomvc.com/ TodoMVC是一款开源的JavaScr ...
- 使用Windows命令行启动关闭服务(net,sc用法)
下面两个命令最好以管理员方式启动cmd窗口,否则出现权限问题. 1.net用于打开没有被禁用的服务, NET命令是功能强大的以命令行方式执行的工具. 它包含了管理网络环境.服务.用户.登陆大部分重要的 ...
- MySql 在cmd下的学习笔记 —— 有关多表查询的操作(内连接,外连接,交叉连接)
mysql> create table test5( -> id int, ) -> )engine myisam charset utf8; Query OK, rows affe ...
- Eclipse使用solrJ 7.7.0连接solr步骤
先写一个测试类: package com.taotao.rest.solrj; import org.apache.solr.client.solrj.SolrClient; import org.a ...
- 用OZ工具制作openstack镜像
在部署openstack云平台环境的时候,需要上传镜像到glance. 首先下载iso镜像,这里下载了centos7.2镜像,放到/iso目录下 然后用OZ工具制作openstack的镜像 1.安装l ...
- ajax跨域请求のJSONP
简单说了一下,JSON是一种基于文本的数据交换方式,或者叫做数据描述格式. JSON的优点: 1.基于纯文本,跨平台传递极其简单: 2.Javascript原生支持,后台语言几乎全部支持: 3.轻量级 ...
- 常用的Character方法
- 论文笔记:Batch Normalization
在神经网络的训练过程中,总会遇到一个很蛋疼的问题:梯度消失/爆炸.关于这个问题的根源,我在上一篇文章的读书笔记里也稍微提了一下.原因之一在于我们的输入数据(网络中任意层的输入)分布在激活函数收敛的区域 ...