翼度科技»论坛 编程开发 JavaScript 查看内容

JavaScript全解析——this指向

4

主题

4

帖子

12

积分

新手上路

Rank: 1

积分
12
本系列内容为JS全解析,为千锋教育资深前端老师独家创作
致力于为大家讲解清晰JavaScript相关知识点,含有丰富的代码案例及讲解。如果感觉对大家有帮助的话,可以【点个关注】持续追更~
this指向(掌握)

this 是一个关键字,是一个使用在作用域内的关键字
作用域分为全局作用域和局部作用域(私有作用域或者函数作用域)
全局作用域

全局作用域中this指向window
局部作用域

函数内的 this, 和 函数如何定义没有关系, 和 函数在哪定义也没有关系,只看函数是如何被调用的(箭头函数除外)
可分为以下场景:
普通函数中调用

普通函数中的this和全局调用一样,this指向window
语法:函数名()
  1. [/code][size=4]对象(包含数组)中调用[/size]
  2. 该函数内的 this 指向 点 前面的内容,也就是那个对象或者数组
  3. 语法:
  4. 对象名.函数名()*
  5. 对象名
  6. [code]
复制代码
定时器处理函数中调用

定时器中的this同样也是指向window
  1. [/code][size=4]事件处理程序中调用[/size]
  2. 事件处理程序中的this指向的是事件源
  3. [code]<!DOCTYPE html>
  4. <html lang="en">
  5. <head>
  6.    <meta charset="UTF-8">
  7.    <meta http-equiv="X-UA-Compatible" content="IE=edge">
  8.    <meta name="viewport" content="width=device-width, initial-scale=1.0">        <title>Document</title>
  9.    
  10. </head>
  11. <body>
  12.    hello world
  13.    
  14. </body>
  15. </html>
复制代码
自执行函数中调用

●自执行函数中的this也指向window
  1. [/code][size=6]强行改变this指向[/size]
  2. 通过上面的学习大家知道,this在不同的情况指向是不同的,但是有时候需要指向一个制定的对象,[b]这就需要改变this的指向[/b]
  3. [b]可以理解成不管之前指向哪里,现在我让你指向哪里你就要指向哪里[/b]
  4. 强行改变this指向的方式可以通过call、apply和bind来改变
  5. [size=5]call调用[/size]
  6. 作用:改变函数内部this的指向
  7. [size=4]语法:[/size]
  8. 函数名.call()
  9. 对象名.函数名.call(参数1,参数2,参数3...)
  10. [size=4]参数:[/size]
  11. ○第一个参数是this要指向的对象
  12. ○从第二个参数开始,依次给函数传递实参
  13. [b]特点:[/b] 会立即调用函数或者说立即执行
  14. [code]
复制代码
apply调用

作用: 改变函数内部this的指向
语法:
○函数名.apply()
○对象名.函数名.apply(参数1,[参数2,参数3...])
参数:
○第一个参数是this要指向的对象
○第二参数的一个数组,要传递的实参要放到数组里面,就是有一个实参也要放到数组里面
特点: 会立即调用函数或者说立即执行
  1. [/code][size=5]bind调用[/size]
  2. [b]作用:[/b] 改变函数内部this的指向
  3. [b]语法:[/b]
  4. 函数名.bind()
  5. 对象名.函数名.bind(参数1,参数2,参数3...)
  6. [b]参数:[/b]
  7. 第一个参数是this要指向的对象
  8. 从第二个参数开始,依次给函数传递实参
  9. [b]特点:[/b] 函数不会立即调用,会返回一个改变this指向以后的函数,使用的时候需要调用
  10. [code]
复制代码
以上即为JS中this指向的一些基础知识点,更多技术干货、知识技巧可以关注我们!有不清楚的问题也可以在评论区交流讨论,也可以私信小千~

来源:https://www.cnblogs.com/qian-fen/p/17391354.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具