简单谈谈JavaScript中的this
是夜,想着考量下小黄毛近期的JavaScript进阶如何了,鉴于近期一直在接触Vue 2.0,索性就围绕this编写了个代码片段,
给其一个测量,毕竟写js的程序员都知道,JavaScript的函数调用时会隐性的接收到两个附加的参数:this和arguments。
1、先上代码:
/**
* this
*/
var ajaxThis = (function() {
global.a = 2;
function fn(b) {
this.b = b;
console.log(this.a);
}
var obj = {
a : 4,
fn : fn
};
fn();// 题1
obj.fn(); // 题2
fn.call(obj); // 题3
fn.call(null);// 题4
fn.apply(obj);// 题5
fn.apply(null);// 题6
var fnInstance = new fn(8);
console.log(fnInstance.b);// 题7
})();
注:这些题倒不难,只要你把握好JavaScript中的this到底指向谁,那么就问题不大。
2、小测验答案
题1:2
题2:4
题3:4
题4:2
题5:4
题6:2
题7:undefined
8
不要好奇,第7题的确是输出两个值
先说些闲话,当你对JavaScript接触使用的多了,就能感受到它的方面之处,同时也能够避开它的缺点,发扬其优点。
在解析答案之前,先来讲解一下到底如何判断this的取值吧。
其实,this的值取决于调用的模式。
调用模式?那都有哪些调用模式呢?
总的来说,JavaScript的函数调用总共有4种模式,是的,你没听错,就是4种!!!
哪4种?
• 方法调用模式
• 普通函数调用模式
• 构造器调用模式
• apply/call调用模式
而针对这四种调用模式,参数this的取值会有所差异:
• 方法调用模式
何为方法调用?当然泛指针对对象来说的了。该种调用模式说明,函数在某个明确的上下文对象中调用时,this绑定的是这个上下文对象。
e g. 题2的 obj.fn(); // 调用的对象是obj,所以this绑定的就是obj,所以fn()内部console.log(this.a)输出的便是obj.a,即为4
• 普通函数调用模式
普通函数调用?指的便是直接调用函数。这种调用模式,默认情况下,如果函数是被直接调用的,则this绑定到全局对象;
如果在严格模式下(即 'use strict'),就绑定到undefined。
e g. 题1中的 fn(); // 因为没有指明调用方,同时又是非严格模式,所以,fn()函数内部的this绑定到全局对象,所以this.a的值为global.a,即为2
• 构造器调用模式
构造器调用模式?这个应该都不陌生吧?!当然指的是通过new操作符来调用的函数啦!在这里有点类似于面向对象编程的概念,构造器函数内部的this当然
绑定到这个新创建的对象了。这种调用模式,指的便是:如果函数通过new操作符调用,this绑定的是新创建的对象。
e g. 题7中的 var fnInstance = new fn(8); // 因为是通过new操作符调用的fn函数,所以this指向当前新创建的对象,然而这个对象没有a这个属性,所以输出undefined
console.log(fnInstance.b); // 然而因为给fn函数传入了值8,所以……
• apply/call调用模式
apply/call又是什么鬼?我先来解说它们的用法吧!
a) apply()和call()方法的第一个参数都是要调用函数的对象。用apply()和call()调用函数时,函数内的this属性总是引用这个参数;
b) call()函数剩余参数是传递给要调用的函数的值,它们的数量可以是任意的;
c) apply()方法和call()方法类似,只不过它只接收两个参数,除了调用者之外,它的第二个参数是一个带下标的集合(比如数组,但也可以不是数据),
apply()方法把这个集合中的元素作为参数传递给调用的函数。
OK,现在重新回到主题:该种调用模式,this又指的是谁?细心的你可能已经注意到,上面介绍他们的用法是,已经提到函数内的this属性总是引用第一个参数,
也就是调用函数的对象。也就是说,函数通过apply/call调用,this绑定的是指定的对象,然而,如果把null/undefined作为this的绑定对象传入apply/call,
在调用时会被忽略,实际应用的是默认绑定规则。
e g. fn.call(obj); // 题3,答案为console.log(obj.a),即为4
fn.call(null);// 题4 ,因为null被忽略,答案为console.log(global.a),即为2
fn.apply(obj);// 题5 ,答案为console.log(obj.a),即为4
fn.apply(null);// 题6 ,因为null被忽略,答案为console.log(global.a),即为2
好了,就总结到这里。小黄毛,你懂了吗?
简单谈谈JavaScript中的this的更多相关文章
- 谈谈javascript中的prototype与继承
谈谈javascript中的prototype与继承 今天想谈谈javascript中的prototype. 通常来说,javascript中的对象就是一个指向prototype的指针和一个自身的属性 ...
- 简单谈谈Python中的几种常见的数据类型
简单谈谈Python中的几种常见的数据类型 计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各种数值.但是,计算机能处理的远不止数值,还可以处理文本.图形.音频.视频.网页等 ...
- 简单分析JavaScript中的面向对象
初学JavaScript的时候有人会认为JavaScript不是一门面向对象的语言,因为JS是没有类的概念的,但是这并不代表JavaScript没有对象的存在,而且JavaScript也提供了其它的方 ...
- 谈谈javascript 中的函数问题
聊聊javascript中的函数 本文可作为李刚<疯狂htmlcssjavas讲义>的学习笔记 先说一个题外话 前几天在知乎上流传着一个对联 上联是雷锋推到雷峰塔 nnd 这是什么对联? ...
- 简单说 JavaScript中的tostring( ) 与 valueOf( )方法
说明 所有的对象都继承有toString() 和 valueOf() 方法,对象到字符串,对象到数字的转换,会通过调用待转换对象的这两个方法中的一个来完成. 解释 toString( )方法的作用是: ...
- 谈谈javascript中的日期Date对象
一.日期对象 在javascript中并没有日期型的数据类型,但是提供了一个日期对象可以操作日期和时间. 日期对象的创建: new Date();二.将日期对象转换为字符串 将日期对象转换为字 ...
- 谈谈 JavaScript 中的 this 指向问题
JavaScript 中的 this 为一个重难点,它不像静态语言 C#.Java 一样,就表示当前对象.而在 JS 中, this 是运行时确定,而并非定义时就已确定其值. 谈起 this ,必须少 ...
- 简单理解Javascript中的call 和 apply
javascript中面向对像的能力是后来加进来的, 为了兼容性, 所以整出了很多奇特的东西, function Animal(){ this.name = "Animal"; t ...
- 简单理解javascript中的原型对象,实现对之间共享属性和行为
javascript中提供了构造函数.可以方便的创建对象. 典型的构造函数例如以下: function Person(name, age) { this.name = name; this.age = ...
随机推荐
- mysql优化———第二篇:数据库优化调整参数
摘要 参数调优内容: 1. 内存利用方面 2. 日志控制方面 3.文件IO分配,空间占用方面 4. 其它相关参数 一 摘要 通过参数提高MYSQL的性能.核心思想如下: 1 提高my ...
- 学习vi(1)
原文地址:http://www.gentoo.org/doc/zh_cn/vi-guide.xml#doc_chap2 1. 新手上路 介绍 本教程将会向你展示如何使用vi──一个强大的可视化编辑器 ...
- Java ThreadFactory接口用法
根据需要创建新线程的对象.使用线程工厂就无需再手工编写对 new Thread 的调用了,从而允许应用程序使用特殊的线程子类.属性等等. JDK中的介绍: An object that creat ...
- iOS开发——UITableView(未完,待续...)
1.让tableview的自定义cell,自动计算高度. self.tableView.estimatedRowHeight = 44.0; self.tableView.rowHeight = UI ...
- C# 计算文件的HASH
/// <summary> /// 提供用于计算指定文件哈希值的方法 /// <example>例如计算文件的MD5值: /// <code> /// String ...
- UnitOfWork实战
企业模式之Unit Of Work模式 在开始UnitOfWork模式之前有必要回顾下我们耳熟能详的Data Access Object(DAO)模式,即数据访问对象.DAO是一种简单的模式,我们构建 ...
- K-Means 算法(转载)
K-Means 算法 在数据挖掘中, k-Means 算法是一种 cluster analysis 的算法,其主要是来计算数据聚集的算法,主要通过不断地取离种子点最近均值的算法. 问题 K-Means ...
- iOS 之 事件响应者链
响应者链表示一系列的响应者对象.事件被交由第一个响应者对象处理,如果第一个响应者不处理,事件就沿着响应者链向上传递,交由下一个响应者(Next responder). View->ViewCon ...
- 利用DIV+CSS制作网页过程中常用的基本概念及标签使用细节
CSS主要用于对HTML文件功能的补充及扩展,其作用就是对HTML文件中各种排版进行设置,达到对网页中字体.颜色.背景.图片等的控制,使网页能够完全依照设计者的想法来显示. CSS可以控制网页的显示, ...
- shc加密shell脚本
下载地址:http://www.datsi.fi.upm.es/~frosal/sources/ 安装 .tgz cd shc- mkdir -p /usr/local/man/man1 这步是必须的 ...