JS中this上下文对象使用方式


Posted in Javascript onOctober 09, 2016

JavaScript 有一套完全不同于其它语言的对 this 的处理机制。 在五种不同的情况下 ,this 指向的各不相同。

有句话说得很在理 -- 谁调用它,this就指向谁

一、全局范围内

在全局范围内使用this ,它将指向全局对象(浏览器中为 window)

var name = 'name1';
console.log(name);

this.name = 'name2';
console.log(name);
console.log(this.name);

window.name = 'name3';
console.log(name);
console.log(this.name);
console.log(window.name);

JS中this上下文对象使用方式

二、函数调用

直接调用一个函数,this 默认会指向全局 (浏览器端为window)

var name = 'name1';
function sayName(){
 console.log(name);
 console.log(this);
}

sayName();
window.sayName();

可以看到

JS中this上下文对象使用方式

还有几个常见的情况,根据谁调用方法就指向谁的原则,this的指向要细看

// 全局 name
var name = 'name1';

var obj = {
 name: 'name2',
 sayName: function(){
    // 调用它的时候 this指向全局
  return function(){
   console.log(this.name);
  };
 },
 changeName: function(){
    // 调用它的时候 this指向全局
  setTimeout(function(){
   this.name = 'name3';
  },0);
 }
};

obj.sayName()();
obj.changeName();
setTimeout(function(){
 console.log(name);
 console.log(obj.name);
},0);

JS中this上下文对象使用方式

像这些类似匿名的函数,默认都是被全局(浏览器下的window)对象调用,要正确地让obj调用,就要指代好

可以用that保持this再进行下一步,或者匿名函数传值,或者使用call/apply/bind改变context等

var name = 'name1';

var obj = {
 name: 'name2',
 sayName: function(){
  var that = this;
  return function(){
   console.log(that.name);
  };
 },
 changeName: function(){
  var that = this;
  setTimeout(function(){
   that.name = 'name3';
  },0);
 }
};

obj.sayName()(); // name2
obj.changeName();
setTimeout(function(){
 console.log(name); // name1
 console.log(obj.name); // name3
},0);

三、作为对象方法的调用

其实就类似上头提到的 obj.sayName()  obj.name 等

这时this会指向这个obj 

四、call/apply/bind 的调用

当使用 Function.prototype 上的 call 或者 apply ,bind 方法时,函数内的 this将会被 显式设置为函数调用的第一个参数。

具体使用方法

我们可以稍微修改一下上头的代码,就可以看到this指向的改变

var name = 'name1';

var obj = {
 name: 'name2',
 sayName: function(){
  // 返回一个默认全局的函数
  return function(){
   console.log(this.name);
  };
 },
 changeName: function(){
  // 返回一个默认全局的函数
  setTimeout(function(){
   this.name = 'name3';
  // 然后将该函数绑定给this(当前obj对象)
  }.bind(this),0);
 }
};

// obj.sayName()这个函数,让obj来调用
obj.sayName().call(obj);
// 让this(也就是全局对象)来调用
obj.sayName().apply(this);

obj.changeName();
setTimeout(function(){
 // 输出更改之后,全局name的值
 console.log(name);
 // 输出更改之后,obj对象中 name的值
 console.log(obj.name);
},0);

JS中this上下文对象使用方式

五、作为构造函数调用

比如 new Foo();

先来看个简单的例子:

var name = 'name1';
function Foo(){
 // 赋值this(当前对象)的name属性值
 this.name = 'name2';
}

// new 构造函数产生一个实例
var foo = new Foo();

console.log(name);
console.log(foo.name);

// 直接调用该函数
Foo();
console.log(name);

JS中this上下文对象使用方式

可以看到,如果函数倾向于和 new 关键词一块使用,则我们称这个函数为构造函数,当new 了之后,this则指向这个心创建的对象(这个new 的过程其实也涉及到了继承机制)。

若直接调用这个函数,this就默认执行全局对象了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
零基础学JavaScript最新动画教程+iso光盘下载
Jan 22 Javascript
ajax更新数据后,jquery、jq失效问题
Mar 16 Javascript
javascript显示用户停留时间的简单实例
Aug 05 Javascript
jQuery插件jFade实现鼠标经过的图片高亮其它变暗
Mar 14 Javascript
jquery中trigger()无法触发hover事件的解决方法
May 07 Javascript
一道常被人轻视的web前端常见面试题(JS)
Feb 15 Javascript
Bootstrap表单布局样式代码
May 31 Javascript
基于vue中解决v-for使用报红并出现警告的问题
Mar 03 Javascript
微信小程序实现单列下拉菜单效果
Apr 25 Javascript
node.js中fs文件系统模块的使用方法实例详解
Feb 13 Javascript
JS使用正则表达式实现常用的表单验证功能分析
Apr 30 Javascript
使用这 6个Vue加载动画库来减少我们网站的跳出率
May 18 Vue.js
JS判断来路是否是百度等搜索索引进行弹窗或自动跳转的实现代码
Oct 09 #Javascript
jQuery Ajax传值到Servlet出现乱码问题的解决方法
Oct 09 #Javascript
BootStrap中Table分页插件使用详解
Oct 09 #Javascript
微信小程序 for 循环详解
Oct 09 #Javascript
微信小程序 条件渲染详解
Oct 09 #Javascript
手机浏览器 后退按钮强制刷新页面方法总结
Oct 09 #Javascript
最实用的jQuery分页插件
Oct 09 #Javascript
You might like
德生PL330的评价与改造
2021/03/02 无线电
php开发留言板的CRUD(增,删,改,查)操作
2012/04/19 PHP
PHP输出日历表代码实例
2015/03/27 PHP
两种方法解决javascript url post 特殊字符转义 + & #
2016/04/13 Javascript
js变量提升深入理解
2016/09/16 Javascript
jQuery层级选择器实例代码
2017/02/06 Javascript
JS实现双击内容变为可编辑状态
2017/03/03 Javascript
uploader秒传图片到服务器完整代码
2017/04/22 Javascript
JS基于正则表达式的替换操作(replace)用法示例
2017/04/28 Javascript
Vue.js学习笔记之修饰符详解
2017/07/25 Javascript
JS实现基于拖拽改变物体大小的方法
2018/01/23 Javascript
浅谈webpack打包之后的文件过大的解决方法
2018/03/07 Javascript
浅谈ElementUI中switch回调函数change的参数问题
2018/08/24 Javascript
vue通过指令(directives)实现点击空白处收起下拉框
2018/12/06 Javascript
详解如何使用node.js的开发框架express创建一个web应用
2018/12/20 Javascript
jQuery实现容器间的元素拖拽功能
2020/12/01 jQuery
JS实现简易日历效果
2021/01/25 Javascript
Python装饰器的函数式编程详解
2015/02/27 Python
浅谈numpy库的常用基本操作方法
2018/01/09 Python
pyqt5实现俄罗斯方块游戏
2019/01/11 Python
Python使用mongodb保存爬取豆瓣电影的数据过程解析
2019/08/14 Python
基于Python中的yield表达式介绍
2019/11/19 Python
nginx搭建基于python的web环境的实现步骤
2020/01/03 Python
keras模型可视化,层可视化及kernel可视化实例
2020/01/24 Python
Pycharm配置autopep8实现流程解析
2020/11/28 Python
Python对excel的基本操作方法
2021/02/18 Python
探讨HTML5移动开发的几大特性(必看)
2015/12/30 HTML / CSS
HTML5中外部浏览器唤起微信分享功能的代码
2020/09/15 HTML / CSS
英国高端食品和葡萄酒超市:Waitrose
2016/08/23 全球购物
彪马加拿大官网:PUMA加拿大
2018/10/04 全球购物
初任培训自我鉴定
2013/10/07 职场文书
幼儿园家长会欢迎词
2014/01/09 职场文书
小学少先队活动方案
2014/02/18 职场文书
教师岗位聘任书范文
2014/03/29 职场文书
党的群众路线调研报告
2014/11/03 职场文书
离职报告格式
2014/11/04 职场文书