最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

js中this的指向问题探讨

来源:动视网 责编:小采 时间:2020-11-27 19:59:22
文档

js中this的指向问题探讨

js中this的指向问题探讨:本文主要和大家分享js中this的指向问题探讨,this关键字代表当前正在执行的方法的对象,如果没有当前方法,则是指全局变量。就是说this代表调用该方法的对象的引用。一、全局作用域或者普通函数中this指向全局对象window。//直接打印 console.log
推荐度:
导读js中this的指向问题探讨:本文主要和大家分享js中this的指向问题探讨,this关键字代表当前正在执行的方法的对象,如果没有当前方法,则是指全局变量。就是说this代表调用该方法的对象的引用。一、全局作用域或者普通函数中this指向全局对象window。//直接打印 console.log


本文主要和大家分享js中this的指向问题探讨,this关键字代表当前正在执行的方法的对象,如果没有当前方法,则是指全局变量。就是说this代表调用该方法的对象的引用。

一、全局作用域或者普通函数中this指向全局对象window。

//直接打印
 console.log(this) //window
//function声明函数
 function bar () {conso
le.log(this)}bar() //window
//function声明函数赋给变量
 var bar = function () {console.log(this)}bar() //window
//自执行函数
 (function () {console.log(this)})(); //window

二、方法调用中谁调用this指向谁

//对象方法调用
 var person = {run: function () {console.log(this)}}person.run()// person
//事件绑定
 var btn = document.querySelector("button")btn.onclick = function () {console.log(this) // btn}
//事件监听
 var btn = document.querySelector("button")btn.addEventListener('click', function () {console.log(this) //btn})
//jquery的ajax
 $.ajax({ self: this, type:"get", url: url, async:true, success: function (res) {console.log(this)
 // this指向传入$.ajxa()中的对象
 console.log(self) // window } }); 
//这里说明以下,将代码简写为$.ajax(obj) ,this指向obj,在obj中this指向window,因为在在success方法中,独享obj调用自己,所以this指向obj

三、在构造函数或者构造函数原型对象中this指向构造函数的实例

//不使用new指向window
 windowfunction Person (name) {console.log(this) // window 
 this.name = name;}Person('inwe')
//使用new
 function Person (name) {this.name = name console.log(this) //people 
 self = this } var people = new Person('iwen') console.log(self === people) //true
//这里new改变了this指向,将this由window指向Person的实例对象people
new改变this指向,将this指向window改为指向person的实例people

改变this的指向:

函数本身就是一个特殊类型,大多数认为是一个变量,this指向谁在函数定义时候确定不了,只有在函数执行时候才可以确定this到底指向谁,实际上this指向的是最终调用他的函数。

文档

js中this的指向问题探讨

js中this的指向问题探讨:本文主要和大家分享js中this的指向问题探讨,this关键字代表当前正在执行的方法的对象,如果没有当前方法,则是指全局变量。就是说this代表调用该方法的对象的引用。一、全局作用域或者普通函数中this指向全局对象window。//直接打印 console.log
推荐度:
标签: 研究 指向 this
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top