javascript中,对于this指向的浅见
# this的指向在函数创建的时候确定不了。只有在执行的时候,才可以确定。
## 1 、 这里的this指向window window.fn(); 所以this.user是undefined
function fn (){
var user='追梦人';
console.log(this.user); // undefined
console.log(this); // window
}
fn();
## 2、谁调用,指向谁
var o ={
user:'追梦人',
fn:function(){
console.log(this.user); // 谁调用,指向谁
}
}
o.fn();
## 3、
var o ={
user:'追梦人',
fn:function(){
console.log(this.user); // 为什么不是undefiend,是window在调用
}
}
window.o.fn(); // 谁调用,指向谁
## 4、
var o={
a:10,
b:{
a:12,
fn:function(){
console.log(this.a); //
},
},
}
o.b.fn();
- - 如果函数中有this,但是他没被上一级的对象所跳用,这时this指向window
- - 如果函数中有this,并且这个函数被上一级对象所调用,这时this指向上一级的对象
- - 如果函数中有this,而且这个函数内部有多个对象,尽管这个函数被最外层所调用,
- - 但是this的指向也只是他的上一级对象。
- - 严格模式中,this不指向window,而是undefined
## 5、 注释掉a:12 this.a为 undefined
var o={
a:10,
b:{
//a:12,
fn:function(){
console.log(this.a);
},
},
}
o.b.fn();
- - 尽管对象b中,没有属性a,但是这个this也是指向对象b,因为this只会指向
- - 它的上一级对象,不管该对象有没有a
## 6、this指向的永远都是最后调用它的对象(执行的时候,谁调用)
var o={
a:10,
b:{
a:12,
fn:function(){
console.log(this.a); // undefined
console.log(this); // window
},
},
}
var fn=o.b.fn; // 注意:这里并没有执行
fn(); // 执行fn
- - 注意:虽然,函数中的fn被对象b所引用,但是在赋值的时候,并没有执行,
- - 所以最终的指向是window
- - 上面的例子不同,因为上面的例子直接执行了fn()
## 7、构造函数中的this
function Fn(){
this.user="追梦人";
}
var fn = new Fn();
console.log(fn.user);
- - 之所以对象a可以用函数Fn中的uesr,是因为new关键字改变了this的指向。
- - new 关键字创建了一个对象实例, 相当于复制了一份Fn到对象a中。
- - 此时,只是创建,没有执行。
- - 最后调用的是fn,那么this指向自然是fn
- - 首先,new关键字会创建一个空对象
- - 然后会自动调用一个函数的apply方法,将this指向这个空对象,这样函数内部的this就会被这个空对象所替代。
- - bind apply(数组) call
## 8、构造函数 return 对象 的时候
function Fn(){
this.user="追梦人";
return {} // 返回 一个对象
}
var fn = new Fn();
console.log(fn.user); // undefined
- - 返回一个对象的时候,this会指向返回的对象
## 9、return 简单类型的数据
function Fn(){
this.user="追梦人";
return 1; // 返回的是一个简单类型
}
var fn = new Fn();
console.log(fn.user); // 追梦人
- - 返回简单类型数据,this还是指向函数的实例
## 10、return null的时候
function Fn(){
this.user="追梦人";
return null; // 返回的是一个简单类型
}
var fn = new Fn();
console.log(fn.user); // 追梦人
- - 注意:返回null虽然是个对象,this还是指向函数的实例,null特殊
javascript中,对于this指向的浅见的更多相关文章
- javascript中this的指向
作为一个前端小白在开发中对于this的指向问题有时候总是会模糊,于是花时间研究了一番. 首先this是JS的关键字,this是js函数在运行是生成的一个内部对象,生成的这个this只能在函数内部使用. ...
- Javascript中的this指向。
一.JavaScript中的函数 在了解this指向之前,要先弄明白函数执行时它的执行环境是如何创建的,这样可以更清楚的去理解JavaScript中的this指向. function fn(x,y,n ...
- JavaScript中 this 的指向
很多人都会被JavaScript中this的指向(也就是函数在调用时的调用上下文)弄晕,这里做一下总结: 首先,顶层的this指向全局对象. 函数中的this按照调用方法的不同,其指向也不同: 1.函 ...
- 前端面试之JavaScript中this的指向【待完善!】
JavaScript中this的指向问题! 另一个特殊的对象是 this,它在标准函数和箭头函数中有不同的行为. 在标准函数中, this 引用的是把函数当成方法调用的上下文对象,这时候通常称其为 t ...
- JavaScript中的this指向
this是谁 技术一般水平有限,有什么错的地方,望大家指正. this代指当前对象super调用父类的构造函数,应表会运网数物,加载驱动建立链接执行SQL处理结果,直到现在每想起这三点就能想起我上大学 ...
- Javascript 中的this 指向的对象,你搞清楚了吗?
Javascript 中的this 总让人感到困惑,你能分清以下三种test1(),test2(),test3() 情况下的输出吗? 注:以下Javascript运行环境中为浏览器 //1 this在 ...
- javascript中的this指向问题
在深入学习JavaScript之后,我们越来越多的会遇到函数或者在对象内部中,对于this的指向问题的疑惑,其实基本上每一个编程语言中都有一个this,这个this的指向都是大同小异,你也可以汉化它的 ...
- 谈谈 JavaScript 中的 this 指向问题
JavaScript 中的 this 为一个重难点,它不像静态语言 C#.Java 一样,就表示当前对象.而在 JS 中, this 是运行时确定,而并非定义时就已确定其值. 谈起 this ,必须少 ...
- JavaScript中this的指向问题
this是面向对象语言中一个重要的关键字,理解并掌握该关键字的使用对于我们代码的健壮性及优美性至关重要.而javascript的this又有区别于Java.C#等纯面向对象的语言,这使得this更加扑 ...
- 轻松几句搞定【Javascript中的this指向】问题
this关键字在JavaScript中扮演了至关重要的角色,每次它的出现都伴随着它的指向问题,这也是很多初学者容易出错的地方. 不过,这篇文章将会带你一次性搞定this指向的问题,望能给大家提供帮助! ...
随机推荐
- Quartz.net使用总结
进来项目中用到了 任务调度 来实现短信发送网关,所以这里分享下 Quartz.net 的使用经验. 任务调度选用了 Quartz.net 来实现,之前用的是C#中自带的window服务安装,这次 ...
- 百度云推送-服务端 C# SDK
思路: 1.公司有项目需要做android和ios手机端推送消息的功能: 2.没有接触过这方面的知识,一头雾水,开始在网上一顿搜,网上倒是有不少解决方案,首先搜的是android的解决方案,因为ios ...
- Delphi 收藏
日前整理仓库,翻出了一些 Delphi 产品,以前购买的 Delphi 都有实体产品,包含说明书.光碟片.还有一些广告文宣,而且相当厚实,版本的演进,从外包装也能感受到,到目前的 XE5 版,只剩一个 ...
- 泛函编程(25)-泛函数据类型-Monad-Applicative
上两期我们讨论了Monad.我们说Monad是个最有概括性(抽象性)的泛函数据类型,它可以覆盖绝大多数数据类型.任何数据类型只要能实现flatMap+unit这组Monad最基本组件函数就可以变成Mo ...
- c#事务用法
ado.net2.0的SqlTransaction使用方法 /////ado.net1.0中使用Transacation(事务) string connectionString = "dat ...
- Java IO 装饰者模式
装饰模式(Decorator) 装饰模式又名包装(Wrapper)模式. 装饰模式以对客户端透明的方式扩展对象的功能,是继承关系的一个替代方案. 装饰模式通过创建一个包装对象,也就是装饰,来包裹真实的 ...
- Linux 学习手记(6): 磁盘、分区、MBR与GPT
1. 磁盘在LINUX中的表示 Linux所有设备都被抽象为一个文件,保存在/dev目录下 设备名称一般为hd[a-z]或者sd[a-z]([a-z]为分区号),如:hda.hdb.sda.sdb I ...
- 在你设计中可能用到的20个杂志 PSD 原型
你是否正在为您的印刷产品找一些现成的原型素材?在这里,我们收集了一组免费的杂志 PSD 素材,必将派上用场.这些原型将给你和你的客户一个先睹为快的产品,在现实生活中看起来如何.所有这些原型提供了可以免 ...
- JavaScript学习笔记-面向对象的模块化编程
面向对象的模块化编程 模块是一个独立的JS文件,模块文件可以包含一个类定义.一组相关的类.一个实用函数库.一些待执行的代码 模块化的目标:支持大规模的程序开发,处理分散源代码的组装,并能让代码正确执行 ...
- ZedGraph饼图---傻瓜版
GraphPane pGraphPane=this.zedGraphControl1.GraphPane;//调用饼图类 pGraphPane.Title.Text = "重金属含量分析图& ...