JavaScript中this的用法 及 如何改变this的指向
要懂得JavaScript中this的用法,首先需要知道,JavaScript中的作用域相关知识。
var fun = function(){
var flag = 1;
console.log(flag);
}
var flag = 0;
fun();
console.log(flag);
首先看上面这段代码,结果 : 1 0
这个很好理解了,打印的函数内部 flag 的值为 1,全局打印 flag 的值为0。
那么再如果函数内部打印 this.flag 呢?
var fun = function(){
var flag = 1;
console.log(this.flag)
}
var flag = 0;
fun();
console.log(flag);
结果: 0 0
this.flag 指向的是当前作用域下的 flag 值,fun() 函数在全局调用,那么作用域便为全局,而全局的 flag 值为 0,遂打印的结果便为 0
那么接下来看看this在不同的几种情况下的指向问题
注意:函数内部的this不是在函数定义时决定的,而是在函数调用时决定的
1、普通的 函数调用方式,内部this指向window(普通函数调用等于window.fun())
function fun(){
console.log(this)
}
var fun = function(){
console.log(this)
}
var fun = function(){
var fun2 = function(){
console.log(this)
}
}
(function(){
console.log(this)
})()
fun()
2、定时器中的this指向window
setTimeout(function(){console.log(this)},1000)
3、构造函数中this的指向(通过new关键字调用才是构造函数)
// 在调用一个方法时,对象.方法名();方法内部this指向调用者
function Fun(name){
this.name = name
}
Student.prototype.fun = function(){
console.log(this.name)
}
var fn = new Fun('Bob')
fn.fun()
4、事件处理程序中,this指向事件源
document.onclick = function(){
console.log(this)
}
改变 this 的指向
1、call 方法:
语法:函数名.call(调用者,实参1,实参2……)
注意:当函数被借用时,会立即执行,并且函数体内this会指向借用者或调用者
function fun(name,age){
this.name = name
this.age = age
}
var obj = {}
fun.call(obj,'Bob',20) ; // 会立即执行一次函数,this指向obj
2、apply 方法:
语法:函数名.apply(调用者,[实参1,实参2……])
注意:当函数被借用时,会立即执行,并且函数体内this会指向借用者或调用者
function fun(name,age){
this.name = name
this.age = age
}
var obj = {}
fun.apply(obj,['Bob',20]) ; // 会立即执行一次函数,this指向obj
3、bind 方法:
语法:函数名.bind(调用者,实参1,实参2……)
注意:当函数被借用时,不会立即执行,会返回一个新的函数,并且新的函数需要我们自己调用
function fun(name,age){
this.name = name
this.age = age
}
var obj = {}
var newFun = fun.bind(obj,'Bob',20)
newFun()
改变 this 指向的 - 栗子
要求:伪数组运用数组的push方法:
// 数组与伪数组的相关知识准备 // 伪数组的特点: // a、伪数组是一个对象 // b、这个对象必须有一个 length 属性 // c、如果这个对象的 length 不为0,那么就要有按下标存储的数据 // d、伪数组没有数组才有的一些方法,比如 push shift 等
// 【伪数组】
var nums = {
0:'a',
1:'b',
2:'c',
3:'d',
length:4
}
// 借用数组中的 push 方法
Array.prototype.push.call(nums,'e','f')
JavaScript中this的用法 及 如何改变this的指向的更多相关文章
- JavaScript中return的用法详解
JavaScript中return的用法详解 最近,跟身边学前端的朋友了解,有很多人对函数中的this的用法和指向问题比较模糊,这里写一篇博客跟大家一起探讨一下this的用法和指向性问题. 1定义 t ...
- javascript中 try catch用法
javascript中 try catch用法 投稿:hebedich 字体:[增加 减小] 类型:转载 时间:2015-08-16我要评论 JS try catch语句一般在什么情况下使用?是必须使 ...
- 从函数调用的角度,探讨JavaScript中this的用法
js函数调用方式大概可分为:函数调用,构造器调用,call或apply,方法调用四种方式.下面结合一些基础概念和实测代码,从函数调用的角度,探讨JavaScript中this的用法. 1. new对函 ...
- JavaScript中this的用法详解
JavaScript中this的用法详解 最近,跟身边学前端的朋友了解,有很多人对函数中的this的用法和指向问题比较模糊,这里写一篇博客跟大家一起探讨一下this的用法和指向性问题. 1定义 thi ...
- 在HTML页面中实时获取新消息的方法 “JavaScript中的setInterval用法”
JavaScript中的setInterval用法(资料来源:博主---八神吻你 ) setInterval动作的作用是在播放动画的时,每隔一定时间就调用函数,方法或对象.可以使用本动作更新来自数 ...
- javaScript中with的用法
1 JavaScript中的with语句的作用是为逐级的对象访问提供命名空间式的速写方式, 也就是在指定的代码区域, 直接通过节点名称调用对象 初次接触到with用法,是这样一段代码: 1 2 3 4 ...
- javascript中的继承用法
本文实例汇总了javascript关于继承的用法,希望本文所述对大家的javascript程序设计有所帮助.分享给大家供大家参考.具体如下:代码如下: /** * 实现子类继承父类,但不会产生多余的属 ...
- JavaScript 中 this 的用法
在 JavaScript 中,this 是动态绑定,或称为运行期绑定的.一般而言,在Javascript中,this 指向函数执行时的当前对象. 由于其运行期绑定的特性,JavaScript 中的 t ...
- JavaScript中一些怪异用法的理解
引言 JavaScript这门语言有些场合的用法还是比较怪异的.这篇文章会尽量将这门语言特有的一些比较特殊的用法收集在一起.就当是平时开发时需要注意的地方吧. 特殊用法收集 1.!!用法 在JavaS ...
随机推荐
- ida脚本学习
#!/usr/bin/env python #coding:utf-8 from idc import * import idaapi import idautils import os os.sys ...
- cocos2d JS 鼠标响应事件
对于PC和超级本,添加鼠标事件的的处理,可以加强用户的体验,其处理逻辑与触摸事件基本一样,多了一些鼠标特有的事件响应 如滚轮事件(onMouseScroll) cc.eventManager.addL ...
- HTTP通信机制
HTTP通信机制是在一次完整的HTTP通信过程中,Web浏览器与Web服务器之间将完成下列7个步骤: 1. 建立TCP连接 在HTTP工作开始之前,Web浏览器首先要通过网络与Web服务器建立连接, ...
- java微信小程序调用支付接口
简介:微信小程序支付这里的坑还是有的,所以提醒各位在编写的一定要注意!!! 1.首先呢,你需要准备openid,appid,还有申请微信支付后要设置一个32位的密钥,需要先生成一个sign,得到pre ...
- HDU 1568 Fibonacci(大数前4位)
转载自:http://blog.csdn.net/thearcticocean/article/details/47615241 分析:x=1234567.求其前四位数: log10(x)=log10 ...
- 第二章 CSS基本属性
1.CSS:层叠样式表 一个元素允许同时应用多种样式,页面元素最终的样式即为多种样式的叠加效果. 2.CSS样式优先级 行内样式表>内部样式表>外部样式表[就近原则] id选择器>类 ...
- flask orm
#查询 #查第一行 session.query(User.id,User.userName,User.password).first() #查所有行 sessi ...
- TP图片上传
//控制器文件 public function index(){ if(!empty($_POST)){ $file = $_FILES["file"]; if(!isset($f ...
- 关于oracle中的数字类型
1.关于number类型. 以下是从其文档中摘录出的一句话: p is the precision, or the total number of significant decimal digits ...
- UML之组件图
基本概念:组件图即是用来描述组件与组件之间关系的一种UML图.组件图在宏观层面上显示了构成系统某一个特定方面的实现结构. 组件图中主要包含三种元素,即组件.接口和关系. 组件图通过这些元素描述了系统的 ...