javascript-this指向问题和JS执行机制


prtyaa
prtyaa 2023-12-26 18:04:22 49561
分类专栏: 资讯

1. 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>

    </style>
</head>

<body>
    <button>点击</button>
    <script>
        // this 指向问题: 一般情况下this的最终指向的是那个调用它的对象

        //1. 全局作用域或者普通函数中this指向全局对象windown(注意定时器里面的this指向windown)
        console.log(this);

        function fn(){
            console.log(this);
        }
        window.fn();

        window.setTimeout(function(){
            console.log(this);
        },1000)
        // 2. 方法调用中谁调用this指向谁
        var o = {
            sayHi: function(){
                console.log(this);
            }
        }
        o.sayHi();

        var btn = document.querySelector('button');
        btn.onclick = function(){
            console.log(this);
        }

        btn.addEventListener('click',function(){
            console.log(this);
        })
        // 3. 构造函数中this指向构造函数的实例
        function Fun(){
            console.log(this);
        }

        var fun = new Fun();

    </script>
</body>

</html>

2. js同步和异步

JS早先是单线程,造成了一些堵塞效果;HTML5提出Web Worker标准,允许JavaScript脚本创建多个线程。于是,JS中出现了同步和异步

2.1 同步任务和异步任务的执行过程

  • 同步任务:同步任务都在主线程上执行,形成一个执行栈。
  • 异步任务:JS的异步是通过回调函数实现的。异步任务相关的回调函数添加到异步队列中(异步队列也称消息队列)。

一般而言,异步任务有以下三种类型:

1. 普通事件,如click、resize等

2. 资源加载,如load,error等

3. 定时器,包括setInterval、setTimeout等

2.2 JS执行机制

  1. 先执行执行栈中的同步任务。
  2. 异步任务(回调函数)放入异步队列中。(此过程不是直接将回调函数放在异步队列中,而是事件触发后回调函数才放入异步队列中)
  3. 一旦执行栈中的所有同步任务执行完毕,系统就会按次序读取异步队列中的异步任务,于是被读取的异步任务结束等待状态,进入执行栈,开始执行
1

代码样例:

<!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>

    </style>
</head>

<body>
    <script>
        console.log(1);
    document.onclick = function(){//只有触发了监听事件,回调函数才会进入任务队列
        console.log(1)
    }
    console.log(2);
        setTimeout(function(){//只有触发了定时器的3秒钟,回调函数才会进入任务队列
            console.log(3);
        },3000);
        console.log(4);
    </script>
</body>

</html>

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=30969
赞同 0
评论 0 条
prtyaaL2
粉丝 1 发表 2553 + 关注 私信
上周热门
如何使用 StarRocks 管理和优化数据湖中的数据?  2969
【软件正版化】软件正版化工作要点  2888
统信UOS试玩黑神话:悟空  2860
信刻光盘安全隔离与信息交换系统  2746
镜舟科技与中启乘数科技达成战略合作,共筑数据服务新生态  1280
grub引导程序无法找到指定设备和分区  1249
华为全联接大会2024丨软通动力分论坛精彩议程抢先看!  169
2024海洋能源产业融合发展论坛暨博览会同期活动-海洋能源与数字化智能化论坛成功举办  169
点击报名 | 京东2025校招进校行程预告  165
华为纯血鸿蒙正式版9月底见!但Mate 70的内情还得接着挖...  161
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
信创开放社区邀请他人注册的具体步骤如下 15
如何玩转信创开放社区—从小白进阶到专家 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

加入交流群

请使用微信扫一扫!