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入门学习中的基础知识,需要的朋友可以参考下 一.简介 各大帖子及文章都会讲 ...
随机推荐
- Confluence 6 SQL Server 数据库驱动修改
从 Confluence 6.4 开始,我们使用官方的 Microsoft SQL Server JDBC 驱动来替换掉开源的 jTDS 驱动.从这个版本开始所有的安装都会默认使用官方的 Micros ...
- Confluence 6 数据库支持的驱动
数据库 驱动已捆绑? JDBC 驱动 备注 更多信息 PostgreSQL 9.4-1202 JDBC 41 driver download 我们推荐你使用 JDBC 4 的驱动. 如果你希望使用更新 ...
- PHP array_combine()
// 需要替换 key 的数组 $arr_old = array( '0' => array('id' => 1, 'name' => 'Carroll'), '1' => a ...
- Penetration testing _internal & wireless Penetration Testing
第一部分 渗透测试步骤 ---参考资料 Ethical Hacking: The Value of Controlled Penetration Tests 下载地址 链接:https://pa ...
- hdu5758 思维,树形dp
/*可以推测从叶子结点传送到叶子节点才能使传送次数最少,如果是偶数个叶子结点,那么传送leaf/2次就是答案,如果是奇数个叶子结点,则还有单独一条链需要覆盖dp[u]表示覆盖完u为根的子树需要走的边数 ...
- 属性(property)的特性(attribute)
属性:对象中可以保存数据的变量 属性的特性: 数据属性的特性(默认值是false):value.writable(可写否) .enumerable(可否枚举).configurable(可否重 ...
- python文件的分类
# 0.获取所有的文件名称列表import os import shutilos.chdir("files")file_list = os.listdir("./&quo ...
- Swap file ".hive-site.xml.swp" already exists
1.使用命令[hadoop@slaver1 conf]$ ls -la查找出隐藏文件,然后删除报出来的错误文件. [hadoop@slaver1 conf]$ rm -rf .hive-site.xm ...
- 弹性和瞬态故障处理库Polly
介绍 本节我们来介绍一款强大的库Polly,Polly是一种.NET弹性和瞬态故障处理库,允许我们以非常顺畅和线程安全的方式来执诸如行重试,断路,超时,故障恢复等策略. Polly针对对.NET 4. ...
- jquery自定义事件
触发事件: $(document).trigger('REMOVE_WEBSITE_MSG'); 判断消息条数为0,触发这个