运行程序,解读this指向---case1
一、分析代码执行结果
var length = 10; function fn() { console.log(this.length); } var obj = { length: 5, method: function (fn) { fn(); arguments[0](); fn.call(obj, 12); } }; obj.method(fn, 1); //10 2 5
fn(); //this指向window,默认绑定,window的length值为10
arguments[0](); //this指向arguments,隐式绑定,arguments的length值为2
fn.call(obj, 12); //this指向obj,显示绑定,obj的length值为5
二、修改下面的代码,使结果不是undefined。
function A(){ function initName(){ this.name = 'camille'; // 这里的this指向window } initName(); } var a = new A(); console.log(a.name); //undefined
方法1
function A(){ var _this = this; // 这里的this指向A{} function initName(){ _this.name = 'camille'; // 这里的_this指向A{ name:"camille" } } initName(); } var a = new A(); console.log(a.name); // camille
方法2
function A(){ function initName(){ this.name = 'camille'; } initName.call(this); // 这里的this指向A{ name:"camille" } } var a = new A(); console.log(a.name);// camille
方法3
function A(){ function initName(){ this.name = 'camille'; // 这里的this指向initName{ name:"camille" } } return new initName(); } var a = A(); console.log(a.name);// camille
方法4
function A(){ (function initName(that){ that.name = 'camille'; // 这里的that指向A{ name:"camille" } })(this); } var a = new A(); console.log(a.name);// camille
方法5
function A(){ } A.prototype.initName = function(){ this.name = 'camille'; // 这里的this指向A{ name:"camille" } } var a = new A(); a.initName(); console.log(a.name);// camille
方法6
function A(){ var name; this.initName = function(){ name = 'camille'; // 这里的this指向A{} } this.getName = function(){ return name; }; this.initName();// 这里的this指向A{} } var a = new A(); console.log(a.getName());// camille
方法7
function A(){ var name; this.initName = function(){ name = 'camille'; } this.getName = function(){ return name; }; this.initName(); } function B(){ A.call(this);// 这里的this指向B{} } var b = new B(); console.log(b.getName());// camille
方法8
function A(){ this.name='camille'; } A.prototype.name='houyi'; var a=new A(); console.log(a.name);// camille delete(a.name); console.log(a.name);// houyi
方法9
function A(){ this.name='camille'; } A.prototype.name='houyi'; var a=new A(); a.name='gamiye'; console.log(a.name);// gamiye delete(a.name); console.log(a.name);// houyi
js寻找对象的方式:先在自身找,找不到才会去原型链上找。
运行程序,解读this指向---case1的更多相关文章
- 操作系统篇-hello world(免系统运行程序)
|| 版权声明:本文为博主原创文章,未经博主允许不得转载. 一.前言 今天起开始分享关于操作系统的相关知识,本人也是菜鸟一个,正处于学习阶段,这整个操作系统篇也是我边学习边总结的一些结果,希 ...
- windows服务编写和“以管理员运行”程序的方法
本文将首先解释如何 创建 一个定期查询可用物理内存并将结果写入某个文本文件的服务.然后指导你完成生成,安装和实现服务的整个过程. 第一步:主函数和全局定义 首先,包含所需的头文件.例子要调用 Win3 ...
- python介绍,计算机核心基础,与运行程序有关的三大核心硬件,操作系统
python介绍,计算机核心基础,与运行程序有关的三大核心硬件,操作系统 引子 python是什么? 什么是编程语言?为何要有编程语言? 什么是编程?什么是程序?什么是进程?为何要编程? 计算机基础 ...
- CYPEESS USB3.0程序解读之---GPIO
CPRESS 官方给出的SDK1.1中(目前最新的SDK),提供了大量的例程供我们开发软件的时候作参考,就像STM32的开发一样提供了库一样,但是又不是库,仅仅是参考例程. 首先看一个简单一点的GPI ...
- Xcode 运行程序,左侧memory 不显示内存
运行程序后,xcode 不显示当前使用的内存情况,问题是打开了僵尸--enable zoombie Objects,关闭即可 打开 product--->SCheme-->EditSChe ...
- C# 管理员身份运行程序
在使用winform程序获取调用cmd命令提示符时,如果是win7以上的操作系统,会需要必须以管理员身份运行才会执行成功,否则无效果或提示错误. 比如在通过winform程序执行cmd命令时,某些情况 ...
- IntelliJ IDEA 配置运行程序
IntelliJ IDEA 对于Javaer开发来说还是很nice的,就是第一次用可能配置项有点生疏,这里就记录一下IntelliJ IDEA 配置运行程序. 1. 点击Edit Config... ...
- Usage: AddDimensionedImage imageFile outputFile eclipse 运行程序出错
关于这个在eclipse中运行java程序的错,首先确认你的jdk,jre是否完整,并且与你的eclipse的位数相同,当然我相信这个错误大家应该都会去检查到. 第二个关于addDimensioned ...
- [原创]Win7、Win8、Win10始终以管理员身份运行程序。
在Win7.Win8.Win10系统中,以管理员身份运行程序很麻烦,一般有以下几种方式: 1.在可执行程序或快捷方式上右键,以管理员身份运行: 2.在可执行程序或快捷方式上右键->属性-> ...
随机推荐
- layoutSubviews总结(转)
- (void)setNeedsDisplay - (void)drawRect 但是是用initWithFrame 进行初始化时,当rect的值不为CGRectZero时,也会触发 You shou ...
- iOS 中的 xml 解析
在ios 中解析xml 的方法有很多种 1.苹果原生 NSXMLParser:SAX方式解析,使用简单 2.第三方框架 libxml2:纯c语言,默认包含在ios sdk中,同时支持DOM 和 SA ...
- <crtdbg.h> 的作用
1.在调试状态下让win程在输出窗口中显示调试信息,可以用_RPTn 宏n为显示参数比如_RPT0(_CRT_WARN,"text"); _RPT1(_CRT_WARN," ...
- centos6.5环境下zookeeper-3.4.6集群环境部署及单机部署详解
centos6.5环境下Zookeeper-3.4.6集群环境部署 [系统]Centos 6.5 集群部署 [软件]准备好jdk环境,此次我们的环境是open_jdk1.8.0_101 zookeep ...
- zabbix系列(二)zabbix3.0.4添加对mysql数据库性能的监控
zabbix3.0.4添加Mysql的监控 zabbix3.0 server已自带mysql的模板了,只需安装agent端,然后在web端给主机增加模板就行了. Agent端操纵 /etc/zabbi ...
- dellR720服务器设置光盘引导流程安装cenos7
1.开机,按F10,进入系统引导界面,选择加载系统选项,并选择redhat 7.1选项 系统提示不支持,选择仍然继续,根据提示设置BIOS设置启动,重启 2.根据提示按F11进入BIOS启动设置,选择 ...
- Linux多台机器配置ssh免登录
.安装ssh. sudo apt-get install ssh. 安装完成后会在~目录(当前用户主目录,即这里的/home/xuhui)下产生一个隐藏文件夹.ssh(ls -a 可以查看隐藏文件). ...
- 前端工程化-webpack简介(一)
本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler).当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependenc ...
- string.intern
在翻<深入理解Java虚拟机>的书时,又看到了2-7的 String.intern()返回引用的测试. 总结一句话: jdk1.7之前,调用intern()方法会判断常量池是否有该字符串, ...
- cf276E 两棵线段树分别维护dfs序和bfs序,好题回头再做
搞了一晚上,错了,以后回头再来看 /* 对于每次更新,先处理其儿子方向,再处理其父亲方向 处理父亲方向时无法达到根,那么直接更新 如果能达到根,那么到兄弟链中去更新,使用bfs序 最后,查询结点v的结 ...