JavaScript全解析-this指向

news2025/1/11 4:16:31


this指向(掌握)

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

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

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

普通函数中调用
●普通函数中的this和全局调用一样,this指向window
●语法:函数名()

<script>
    // 全局使用 this
    console.log(this) //window
    console.log(window) //window
    console.log(window === this) //true
    //普通函数调用
    function fn() {
        console.log('我是全局 fn 函数')
        console.log(this) //window
    }
    fn()
</script>


复制代码

文章底部扫码,免费领取前端资料大礼包!

对象(包含数组)中调用
●该函数内的 this 指向 点 前面的内容, 也就是那个对象或者数组
●语法:
○对象名.函数名()*
○对象名

<script>
    //对象函数调用
    function fn() {
        console.log(this) //{fun: ƒ}
    }
    var obj = {
        fun: fn
    }
    obj.fun()
    obj['fun']()
</script>


复制代码

定时器处理函数中调用
●定时器中的this同样也是指向window

<script>
    // 定时器处理函数
    setTimeout(function() {
        console.log(this); //window
    }, 1000)
</script>


复制代码

文章底部扫码,免费领取前端资料大礼包!

事件处理程序中调用
●事件处理程序中的this指向的是事件源

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div {
            width: 200px;
            height: 200px;
            background-color: red;
        }
    </style>
</head>

<body>
    <div>hello world</div>
    <script>
        var res = document.querySelector('div')

        res.onclick = function() {
            console.log(this); //<div></div>
        }
    </script>
</body>

</html>


复制代码

自执行函数中调用
●自执行函数中的this也指向window

<script>
    (function() {
        console.log(this); //window
    })()
</script>


复制代码

强行改变this指向
●通过上面的学习大家知道,this在不同的情况指向是不同的,但是有时候需要指向一个制定的对象
●这就需要改变this的指向
●可以理解成不管之前指向哪里,现在我让你指向哪里你就要指向哪里
●强行改变this指向的方式可以通过call、apply和bind来来改变

call调用
●作用:改变函数内部this的指向
●语法:
○函数名.call()
○对象名.函数名.call(参数1,参数2,参数3...)
●参数:
○第一个参数是this要指向的对象
○从第二个参数开始,依次给函数传递实参
●特点:会立即调用函数或者说立即执行


<script>
    function fn(a, b) {
        console.group('fn 函数内的 打印')
        console.log('this : ', this)
        console.log('a : ', a)
        console.log('b : ', b)
        console.groupEnd()
    }
    var obj = {
        name: '我是 obj 对象'
    }
    var arr = [100, 200, 300, 400, 500]
    // 用 call 调用
    fn.call(obj, 100, 200)
    fn.call(arr, 1000, 2000)
    /*
    this :  {name: '我是 obj 对象'}
    a :  100
    b :  200
    fn 函数内的 打印
    this :  (5) [100, 200, 300, 400, 500]
    a :  1000
    b :  2000
    */
</script>

复制代码

文章底部扫码,免费领取前端资料大礼包!

apply调用
●作用:改变函数内部this的指向
●语法:
○函数名.apply()
○对象名.函数名.apply(参数1,[参数2,参数3...])
●参数:
○第一个参数是this要指向的对象
○第二参数的一个数组,要传递的实参要放到数组里面,就是有一个实参也要放到数组里面
●特点:会立即调用函数或者说立即执行

<script>
    function fn(a, b) {
        console.group('fn 函数内的 打印')
        console.log('this : ', this)
        console.log('a : ', a)
        console.log('b : ', b)
        console.groupEnd()
    }
    var obj = {
        name: '我是 obj 对象'
    }
    var arr = [100, 200, 300, 400, 500]
    // 用 apply 调用
    fn.apply(obj, [100, 200]) 
    fn.apply(arr, [1000, 2000])
    /*
    fn 函数内的 打印
     this :  {name: '我是 obj 对象'}
     a :  100
     b :  200
     fn 函数内的 打印
     this :  (5) [100, 200, 300, 400, 500]
     a :  1000
     b :  2000
    */
</script>


复制代码

bind调用
●作用:改变函数内部this的指向
●语法:
○函数名.bind()
○对象名.函数名.bind(参数1,参数2,参数3...)
●参数:
○第一个参数是this要指向的对象
○从第二个参数开始,依次给函数传递实参
●特点:函数不会立即调用,会返回一个改变this指向以后的函数,使用的时候需要调用

<script>
    function fn(a, b) {
        console.group('fn 函数内的 打印')
        console.log('this : ', this)
        console.log('a : ', a)
        console.log('b : ', b)
        console.groupEnd()
    }
    var obj = {
        name: '我是 obj 对象'
    }
    var arr = [100, 200, 300, 400, 500]
    // 用 bind 调用
    // 注意: 因为是 bind, 不会把 fn 函数执行, 而是把 fn 
    // res 接受的就是 bind 方法复制出来的 fn 函数, 和 fn 
    var res = fn.bind(obj, 100, 200)
    var res1 = fn.bind(arr, 1000, 2000)
    res()
    res1()
    /*
    fn 函数内的 打印
    this :  {name: '我是 obj 对象'}
    a :  100
    b :  200
    fn 函数内的 打印
    this :  (5) [100, 200, 300, 400, 500]
    a :  1000
    b :  2000
    */
</script>


如果上面的文章看着比较枯燥,点击下面的链接直接观看:
千锋教育JavaScript全套视频教程(10天学会Js,前端javascript入门必备)

也可以扫码直接观看视频哦!绝对的干货满满,更多精彩视频B站搜索“千锋教育” 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/537375.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

OS之作业调度算法

目录 一、基本概念 二、先来先服务算法(FCFS) 三、短作业算法(SJF/SPF) 四、轮转调度算法(RR) 五、优先级调度算法 六、多级反馈队列调度算法 一、基本概念 T(周转)T(完成)-T(到达) 二、先来先服务算法(FCFS) 不利于短作业&#xff0c;非抢占式算法 算法思想&#xff…

Linux日志文件服务器搭建

文章目录 Linux日志文件服务器搭建节点规划案例实施(1)修改主机名(2)配置日志服务器(3)重新启动查看rsyslogd(4)配置客户端(5)测试 Linux日志文件服务器搭建 节点规划 IP主机名节点192.168.100.10serverlog日志服务器192.168.100.20clientlog日志客户端 必须两台机器可以ping…

IPv6之组播地址分类

本文目录 1、IPv6组播地址的结构2、特殊的预留地址和预留组播地址 1、IPv6组播地址的结构 IPv6组播地址是由固定的8bit地址前缀FF::/8&#xff0c;4bit的标志位&#xff0c;4bit组播范围和112bit多播组标识符&#xff08;组ID&#xff09;组成 FF::/8 IPv6的组播地址的最高8bi…

linux环境下设置python定时任务

linux环境下设置python定时任务 Linux 系统提供了使用者控制计划任务的命令 :crontab 命令 1、在linux环境执行命令,进入编辑界面 crontab -e2、按键盘 i 键&#xff0c;进入编辑模式&#xff0c;输入以下内容&#xff0c;设置2个定时任务 定时任务1&#xff1a;每隔10分钟执…

MindFusion.JavaScript Pack 2023.R1 Crack

图表控件添加了径向树布局和套索缩放工具。 2023年5月17日-10:53新版 特征 JavaScript图表中的新增功能 径向树布局-添加了新的类&#xff0c;它将树级别排列在围绕根的同心圆中。 套索缩放工具-控件现在支持使用套索工具进行缩放的几种方法&#xff1a; 可以将行为属性设置为…

单点登录协议

认证和授权 认证&#xff1a;确认该用户的身份是他所声明的那个人 授权&#xff1a;根据用户身份授予他访问特定资源的权限 当用户登录应用系统时&#xff0c;系统需要先认证用户身份&#xff0c;然后依据用户身份再进行授权。认证与授权需要联合使用&#xff0c;才能让用户真…

浏览器网络请求——HTTP详解

文章目录 HTTP 是什么HTTP 发展历程HTTP 1.0HTTP 1.1HTTP 2.0 常用方法头部信息 (Headers)请求头&#xff08;request Headers响应头&#xff08;response Headers&#xff09; 状态码HTTP无状态理解&#xff1a;cookie与session总结 HTTP 是什么 HTTP&#xff08;Hyper Text T…

【Linux】2.4 第一个小程序——进度条(C语言)

文章目录 character缓冲区的问题&#xff1a;ps. sleep 函数 倒计时进度条1.打印进度条2.让进度条“动起来”3.预留进度条的位置并用提示符显示进度条的状态4.颜色打印只用颜色来表示进度条 character 回车 与 换行 键盘上的 Enter 键&#xff1a; 换行的过程&#xff1a; …

程序员如何成为一名独立开发者?

这里有一个最简单粗暴的方式让你确定你是否能成为一个独立的开发者。 Lv.1 顺畅地完成一个独立外包项目 一个最低成本的试错方式就是去独立地完成一个外包项目&#xff0c;一般来说外包项目的难度较低&#xff0c;但也具有作为开发者必备的大多数流程&#xff0c;如果不确定自…

ChatGPT+小红书爆文,牛!

随着AI技术的不断发展&#xff0c;它已经逐渐渗透到了我们的生活之中&#xff0c;包括内容营销领域。 我们通过AI算法生成文本、优化搜索引擎排名、提高用户体验等&#xff0c;现在AI已逐渐在改变时代的进步&#xff0c;AI也将成为下一个十年的一个变革。我们每个创业者、内容…

Go的开发工具

Go的开发工具 1.VSCode 开源地址: GitHub - microsoft/vscode: Visual Studio Code 官网&#xff1a;https://code.visualstudio.com 好处是免费的&#xff0c;插件多&#xff01;&#xff01;&#xff01; 2.GoLand 收费&#xff0c;是和IDEA是类似的&#xff0c;非常强。…

零基础转行从事云计算运维工作,不得不掌握的几项技能

转行云计算运维已成为今年热门话题之一&#xff0c;面对内卷严重的Java领域&#xff0c;虽然高薪有前景&#xff0c;但是很多人都是望而止步&#xff0c;自己的实力不允许自己卷入这场“高薪职业争夺战”。于是新的IT热门转行职业云计算被重点关注&#xff0c;它会不会成为下一…

如何使用SCQA模型提高表达能力

SCQA架构是“结构化表达”工具。 一、什么是“SCQA架构”&#xff1f;‍ S&#xff08;Situation&#xff09;情景——由熟悉的情境或事实引入 C&#xff08;Complication&#xff09;冲突——指出实际面临的困境或冲突 Q&#xff08;Question&#xff09;疑问——你如何分析…

【开发日志】2023.05 NormalMap Back To Sphere

【开发日志】2023.03.04 ZENO----SimpleGeometry----CreateSphere_EndlessDaydream的博客-CSDN博客CreateSpherehttps://blog.csdn.net/Angelloveyatou/article/details/129178914(4条消息) 【开发日志】2023.04 ZENO----Composite----CompNormalMap_EndlessDaydream的博客-CSD…

Linux-CentOS7安装Oracle11g 11.2.0.1.0

CentOS7安装Oracle11g 下载yum包更新RPM包解压安装包至tmp目录关闭selinux关闭防火墙创建Oracle用户修改内核配置文件创建安装目录和设置文件权限设置环境变量编辑静默安装响应文件安装打开一个新终端使用root用户登录启动监听建立数据库进程查询查看监听状态sqlplus登录设置开…

pgzero所有知识点详解

目录 什么是pgzero&#xff1f; pgzero的安装 4&#xff0c;正式开始&#xff01; 1&#xff0c;调整背景色 2&#xff0c;导入角色 3&#xff0c;鼠标事件 5&#xff0c;按键事件 6&#xff0c;刷新功能 1&#xff0c;角色属性 2&#xff0c;功能介绍 7&#xff0c;…

Java面试 异常

文章目录 1. Java 异常类层次结构概览图2. Exception 和 Error 有什么区别&#xff1f;3. Checked Exception 和 Unchecked Exception 有什么区别&#xff1f;4. Throwable 类常用方法有哪些&#xff1f;5. try-catch-finally 如何使用&#xff1f;6. finally 中的代码一定会执…

chatGPT VS 科大讯飞星火大模型 使用初体验,到底谁更胜一筹?

下午这会有时间&#xff0c;正好之前申请了讯飞星火大模型的体验&#xff0c;这里就想着简单使用体验对比一下chatGPT和星火大模型的差异&#xff0c;废话不多说这里直接上图&#xff1a; 【诺特兰德叶黄素与纯天然蔬菜中的叶黄素有什么区别】 【今年六月份我就要参加高考了&am…

Python实战案例03

文章目录 1、归并排序2、角谷猜想3、兔子数列4、学生管理系统5、饮品自动售货机6、信息安全策略——文件备份7、用户账户管理1、归并排序 先将待排序的序列划分成若干长度为 1 的子序列,依次将两个子序列排序后合并成长度为 2 的子序列;再依次将两个子序列排序后合并成长度为…

基于Yolov8的道路缺陷检测,加入PConv、WIOU 、DCNV2提升检测精度

1.数据集介绍 缺陷类型:crack 数据集数量:195张 1.1数据增强,扩充数据集 通过medianBlur、GaussianBlur、Blur3倍扩充得到780张图片 按照train、val、test进行8:1:1进行划分 1.1.1 通过split_train_val.py得到trainval.txt、val.txt、test.txt # coding:utf-8import…