this 相关(2)
this 的指向与所在方法的调用位置有关,而与方法的声明位置无关
var obj = {
val: 1,
getVal: function() {
console.log(this.val);
}
}
var obj1 = {
val: 2,
getVal: obj.getVal //相当于obj中的getVal被复制了一份放在obj1中,并给了它的属性getVal
}
obj.getVal(); //
obj1.getVal(); //
在浏览器中,调用方法没有明确对象的,this指向window
var obj = {
val: 1,
getVal: function() {
console.log(this.val);
}
}
var val = 3;
var getVal = obj.getVal;
getVal(); // 在node环境是undefined(node全局对象是global) 在浏览器中是3(浏览器全局对象是window)
1 var obj = {
2 val: 1,
3 getVal: function() {
4 console.log(this.val);
5 }
6 }
7 var obj1 = {
8 val: 2,
9 getVal: function() {
10 var getVal = obj.getVal; //相当于obj中的getVal被复制了一份放在obj1中,并给了它的属性getVal
11 getVal();
12 }
13
14 }
15 var val = 34;
16 obj1.getVal(); //实际上是在这调用的 (在node环境是undefined(node全局对象是global) 在浏览器中是34(浏览器全局对象是window))
在浏览器中setTimeout,setInterval和匿名函数执行的时的当前对象是全局对象window
var that = this; (function() {
console.log(this === that); // 在浏览器中是true 在node是false
})(); setTimeout(function() {
console.log(this === that); // 在浏览器中是true 在node是true
}, 0);
如果js中定义的全局对象在浏览器中是执行window,会加入window中的一个同名属性,但是在node中就一定加到global中了吗,并不是,在node 中是有个global全局作用域,但是除非你指名加到global上,global上面才会有,否则不会有,node的多有文件也不会访问到这个属性,node其实是有文件作用域的,把变量定义在文件中,其他文件是不会共享这个变量的。这是和浏览器的window是不同的哦
applay/call/bind能够强制改变函数执行时的当前对象,让this指向其他对象
var obj = {
val: 1,
getVal: function() {
console.log(this.val);
}
}
var obj1 = {
val: 2
}
var val = 34;
// 调用位置
obj.getVal.call(); //node下是undefined //浏览器下是34 不传值默认是全局对象
obj.getVal.call(obj1); //2
obj.getVal.apply(); //node下是undefined //浏览器下是34 不传值默认是全局对象
obj.getVal.apply(obj1); //
obj.getVal.bind(this)(); //node下是undefined //浏览器下是34
obj.getVal.bind(obj1)(); //
严格模式下 this不会被赋值到window下 而是undefined
(function() {
'use strict'; function getVal() {
console.log(this);
} console.log(this); // undefined
getVal.call(this); // undefined
getVal.call(null); // null
getVal.call(undefined); // undefined
})();
this 相关(2)的更多相关文章
- 嵌入式单片机STM32应用技术(课本)
目录SAIU R20 1 6 第1页第1 章. 初识STM32..................................................................... ...
- java中的字符串相关知识整理
字符串为什么这么重要 写了多年java的开发应该对String不陌生,但是我却越发觉得它陌生.每学一门编程语言就会与字符串这个关键词打不少交道.看来它真的很重要. 字符串就是一系列的字符组合的串,如果 ...
- SQL Server相关书籍
SQL Server相关书籍 (排名不分先后) Microsoft SQL Server 企业级平台管理实践 SQL Server 2008数据库技术内幕 SQL Server性能调优实战 SQL S ...
- dotNET跨平台相关文档整理
一直在从事C#开发的相关技术工作,从C# 1.0一路用到现在的C# 6.0, 通常情况下被局限于Windows平台,Mono项目把我们C#程序带到了Windows之外的平台,在工作之余花了很多时间在M ...
- 在ASP.NET Core应用中如何设置和获取与执行环境相关的信息?
HostingEnvironment是承载应用当前执行环境的描述,它是对所有实现了IHostingEnvironment接口的所有类型以及对应对象的统称.如下面的代码片段所示,一个HostingEnv ...
- virtualbox linux虚拟机相关
linux虚拟机设置为静态IP 在virtualbox中安装好linux虚拟机后,如果采用的是NAT方式的话,linux虚拟机默认采用dhcp方式自动上网,而且用的是NetworkManager服务而 ...
- WebGIS中等值面展示的相关方案简析
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 等值面是气象.环保等相关项目上常用到的效果展示.在传统的CS项 ...
- .NET同步与异步之相关背景知识(六)
在之前的五篇随笔中,已经介绍了.NET 类库中实现并行的常见方式及其基本用法,当然.这些基本用法远远不能覆盖所有,也只能作为一个引子出现在这里.以下是前五篇随笔的目录: .NET 同步与异步之封装成T ...
- zookeeper集群的搭建以及hadoop ha的相关配置
1.环境 centos7 hadoop2.6.5 zookeeper3.4.9 jdk1.8 master作为active主机,data1作为standby备用机,三台机器均作为数据节点,yarn资源 ...
- mysql 5.7中的用户权限分配相关解读!
这篇文章主要介绍了MySQL中基本的用户和权限管理方法,包括各个权限所能操作的事务以及操作权限的一些常用命令语句,是MySQL入门学习中的基础知识,需要的朋友可以参考下 一.简介 各大帖子及文章都会讲 ...
随机推荐
- php回调函数的概念及实例
php提供了两个内置函数call_user_func()和call_user_func_array()提供对回调函数的支持.这两个函数的区别是call_user_func_array是以数组的形式接收 ...
- Python继承、方法重写
继承 在编写类时,并不是每次都要从空白开始.当要编写的类和另一个已经存在的类之间存在一定的继承关系时,就可以通过继承来达到代码重用的目的,提高开发效率. class one(): "&quo ...
- AI学习吧-REDIS-常识
Redis 是一个non-sql,非关系型数据库,数据存放在内存中,支持持久化,redis中的数据会在一段时间内和(mysql等数据库)磁盘进行同步,防止丢失,这样也就降低了读数据效率. Redis和 ...
- 微信小程序 如何获取用户code
1.首先需要获取code 使用 wx.login({ success: function(res) { console.log(res);//这里的返回值里面便包含code }, fail: func ...
- 论文阅读笔记三十:One pixel attack for fooling deep neural networks(CVPR2017)
论文源址:https://arxiv.org/abs/1710.08864 tensorflow代码: https://github.com/Hyperparticle/one-pixel-attac ...
- 论文阅读笔记一:Tutorial on Gabor Filters
时域下的一维Gabor滤波器: 可以将Gabor滤波器看作是两个输出两个相位的滤波器,分别在实数域和虚数域上. 实数域上滤波器为: 虚数域上滤波器为: 傅里叶变换为频域: 上述两个滤波器对频率敏感,为 ...
- 51 NOd 1459 迷宫游戏 (最短路径)
1459 迷宫游戏 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 你来到一个迷宫前.该迷宫由若干个房间组成,每个房间都有一个得分,第一次进入这个房间, ...
- IDEA快捷键之for循环
intelliJ生成for循环代码. 迭代器for循环 iter Iterate iterable | Array in J2SDK 5 syntax itar Iterate elements of ...
- 阻止Java反编译蛋疼方法
public class landv { private static String companyName="landv测试"; public static void main( ...
- 安装淘宝npm(cnpm)
https://www.cnblogs.com/yominhi/p/7039795.html http://npm.taobao.org/ 初始化一个 mpvue 项目 现代前端开发框架和环境都是需要 ...