面试 JavaScript 框架八股文十问十答第八期

面试 JavaScript 框架八股文十问十答第八期

作者:程序员小白条,个人博客

相信看了本文后,对你的面试是有一定帮助的!关注专栏后就能收到持续更新!

⭐点赞⭐收藏⭐不迷路!⭐

1)实现call、apply 及 bind 函数

下面是简单的 JavaScript 实现 callapplybind 函数的示例:

// 实现 call 函数
Function.prototype.myCall = function(context, ...args) {// 确保传递的上下文是对象,如果未传递或传递的是 null 或 undefined,则默认为全局对象context = context || window;// 在传入的上下文对象中创建一个临时函数,以便调用原函数context.tempFunction = this;// 调用原函数const result = context.tempFunction(...args);// 删除临时函数delete context.tempFunction;// 返回原函数的执行结果return result;
};// 实现 apply 函数
Function.prototype.myApply = function(context, argsArray) {// 确保传递的上下文是对象,如果未传递或传递的是 null 或 undefined,则默认为全局对象context = context || window;// 在传入的上下文对象中创建一个临时函数,以便调用原函数context.tempFunction = this;// 调用原函数const result = context.tempFunction(...argsArray);// 删除临时函数delete context.tempFunction;// 返回原函数的执行结果return result;
};// 实现 bind 函数
Function.prototype.myBind = function(context, ...args) {const fn = this;// 返回一个新的函数return function(...newArgs) {// 在调用时使用 myCall 方法,传入指定的上下文和参数return fn.myCall(context, ...args, ...newArgs);};
};

2)异步编程的实现方式?

在 JavaScript 中,异步编程的实现方式有多种,包括回调函数、Promise、Generator、Async/Await 等。下面是一些常见的异步编程实现方式:

  • 回调函数(Callback): 将函数作为参数传递给另一个函数,在异步操作完成后调用该函数。
  • Promise: 使用 Promise 对象进行异步操作的管理,通过 then() 方法处理异步操作的结果,可以链式调用多个异步操作。
  • Generator: 使用 Generator 函数可以暂停和恢复代码执行,配合遍历器对象可实现异步操作的同步化写法。
  • Async/Await: 是基于 Promise 的一种异步编程语法糖,使用 asyncawait 关键字让异步代码看起来像同步代码,更易读和维护。

3)setTimeout、Promise、Async/Await 的区别

  • setTimeout: 是 JavaScript 的一个全局函数,用于在一定的时间后执行指定的代码。
  • Promise: 是 ECMAScript 6 新增的一个异步编程解决方案,用于处理异步操作。它可以将异步操作的成功结果和失败原因封装成一个 Promise 对象,可以链式调用 then() 方法处理异步操作的结果。
  • Async/Await: 是 ECMAScript 2017 的新增特性,用于简化 Promise 的使用。async 函数声明异步函数,可以在函数内部使用 await 关键字等待 Promise 对象的处理结果,使异步代码看起来更像同步代码。

主要区别如下:

  • setTimeout: 是用于延迟执行一段代码,是一种简单的定时器机制。
  • Promise: 是一种用于处理异步操作的对象,可以处理异步操作的成功或失败。
  • Async/Await: 是一种基于 Promise 的异步编程语法糖,可以更方便地编写异步代码,使其看起来像同步代码一样易读易维护。

4)对Promise的理解

Promise(承诺): Promise 是 JavaScript 中用于处理异步操作的一种机制,它表示一个异步操作的最终完成或失败,并返回相应的结果。Promise 对象可以处于以下三种状态之一:

  • Pending(进行中): 初始状态,表示异步操作正在进行中,尚未完成。
  • Fulfilled(已完成): 表示异步操作已经成功完成,可以获取到异步操作的结果。
  • Rejected(已失败): 表示异步操作失败,无法获得异步操作的结果。

Promise 对象具有以下特点:

  • Promise 对象一旦状态改变,就会凝固,无法再次改变。
  • Promise 支持链式调用,可以通过 then() 方法指定异步操作成功和失败时的回调函数。

5)Promise的基本用法

下面是 Promise 的基本用法:

// 创建一个 Promise 对象
const myPromise = new Promise((resolve, reject) => {// 执行异步操作setTimeout(() => {const randomNumber = Math.random();if (randomNumber > 0.5) {// 异步操作成功,调用 resolve 方法resolve(randomNumber);} else {// 异步操作失败,调用 reject 方法reject(new Error('Random number is less than 0.5'));}}, 1000);
});// 使用 then() 方法处理异步操作的结果
myPromise.then(// 处理成功情况(result) => {console.log('Async operation succeeded:', result);},// 处理失败情况(error) => {console.error('Async operation failed:', error);}
);

6)Promise解决了什么问题

Promise 解决了 JavaScript 异步编程中的回调地狱(Callback Hell)问题。在以往的回调函数中,多个异步操作嵌套使用时,代码结构会变得非常复杂和难以维护,容易出现回调地狱的情况。而使用 Promise 可以通过链式调用 then() 方法来处理异步操作的结果,使代码更加清晰和可读,减少了回调嵌套的层级,提高了代码的可维护性和可扩展性。

7)Promise.all和Promise.race的区别的使用场景

  • Promise.all: 接受一个包含多个 Promise 的可迭代对象(如数组),返回一个新的 Promise。这个新的 Promise 在传入的所有 Promise 都成功完成时才会被成功解决,如果有一个 Promise 失败,则整个 Promise.all 将被拒绝。

    const promises = [promise1, promise2, promise3];Promise.all(promises).then(results => {// 所有 Promise 都成功,results 是一个包含所有成功结果的数组}).catch(error => {// 任何一个 Promise 失败,error 是第一个失败 Promise 的原因});
    
  • Promise.race: 也接受一个包含多个 Promise 的可迭代对象,返回一个新的 Promise。这个新的 Promise 在传入的 Promise 中有一个率先解决(无论是成功还是失败),则它就会解决或拒绝。

    const promises = [promise1, promise2, promise3];Promise.race(promises).then(result => {// 第一个率先解决的 Promise 成功,result 是第一个成功的结果}).catch(error => {// 第一个率先解决的 Promise 失败,error 是第一个失败 Promise 的原因});
    

使用场景:

  • Promise.all: 当需要等待多个异步操作都完成,并且需要所有结果时,例如同时请求多个资源时。
  • Promise.race: 当只需要获取最先完成的异步操作结果,例如设置一个超时机制,只关心最先返回的结果。

8)对async/await 的理解

  • async: async 关键字用于声明一个函数是异步的。异步函数会返回一个 Promise 对象,可以使用 await 关键字在异步函数内部等待其他 Promise 对象的解决或拒绝。
  • await: await 关键字用于暂停异步函数的执行,等待 Promise 对象解决,然后返回解决的结果。await 只能在异步函数内部使用。
async function example() {const result = await someAsyncFunction();console.log(result);
}

9)await 到底在等啥?

await 关键字等待的是一个 Promise 对象的解决。当在异步函数中使用 await 时,它会暂停函数的执行,直到等待的 Promise 对象解决为止。如果等待的 Promise 对象解决了,await 表达式会返回解决的值;如果 Promise 对象被拒绝,await 表达式会抛出拒绝的原因。

async function example() {try {const result = await someAsyncFunction(); // 等待 someAsyncFunction 的解决或拒绝console.log(result); // 如果解决,打印解决的值} catch (error) {console.error(error); // 如果拒绝,打印拒绝的原因}
}

10)async/await的优势

  • 清晰简洁: 使用 async/await 使异步代码看起来更像同步代码,提高了代码的可读性和可维护性。
  • 错误处理: 使用 try/catch 块捕获异步操作的错误,使错误处理更加直观,而不需要使用回调函数或链式的 .catch()。
  • 逻辑结构: 使用 async/await 可以更自然地表示异步操作的逻辑结构,避免了回调地狱,使代码层次更加清晰。
  • 同步风格: 使得异步代码可以按照同步的方式编写,提高了代码的可读性,也使得编写异步代码更加容易。

开源项目地址:https://gitee.com/falle22222n-leaves/vue_-book-manage-system

已 300 + Star!

⭐点赞⭐收藏⭐不迷路!⭐

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

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

相关文章

【算法与数据结构】496、503、LeetCode下一个更大元素I II

文章目录 一、496、下一个更大元素 I二、503、下一个更大元素II三、完整代码 所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。 一、496、下一个更大元素 I 思路分析:本题思路和【算法与数据结构】739、LeetCode每日温度类似…

案例:爬取豆瓣电影 Top250 的数据

这是一个简单的Python爬虫案例,通过发送 HTTP 请求,解析网页内容,提取目标信息,并循环爬取多页数据,最终获得了豆瓣电影 Top250 的电影名称、评分、评价人数等信息。您可以根据这个示例来编写其他爬虫案例,…

魔塔游戏

1.题目 这道题是2024-2-6的签到题,题目难度中等。 考核的知识点为:贪心算法优先队列。 题目链接:魔塔游戏 小扣当前位于魔塔游戏第一层,共有 N 个房间,编号为 0 ~ N-1。每个房间的补血道具/怪物对于血量影响记于数…

嵌入式硬件越老越吃香,确实没错!

不知不觉已经从事硬件设计7年多了,7年对于一个从事硬件设计来说能有几个完整的生涯。2016年毕业,2023年即将结束,我已经在汽车这行业“摸爬滚打”了7年的时光。 回顾这7年,自己真的成长了很多很多。有项目失败整改的经验收获&…

Linux进程间通信(IPC)

要想进程间通信,数据交换,必须通过内核; 一个进程将数据写到内核,然后另一个进程从内核读走数据。 IPC:进程间通信(interprocess communication) 通信方式: 管道信号共享映射区(…

假期day7

设计qq界面 代码 ui->lab1->setPixmap(QPixmap(":/pictrue/denglu.webp"));ui->lab1->setScaledContents(true);ui->lab2->setPixmap(QPixmap(":/pictrue/passwd.jpg"));ui->lab2->setScaledContents(true);ui->lab3->setP…

过年在家玩幻兽帕鲁,腾讯云和阿里云Palworld新年礼物

过年在家玩幻兽帕鲁Palworld,阿里云和腾讯云助力玩家一键全自动部署幻兽帕鲁服务器,成本仅需26元,联机三五好友一起开黑,春节畅玩幻兽帕鲁,自建4核16G或8核32G配置,稳定不卡,不用担心官方服务器…

fast.ai 深度学习笔记(三)

深度学习 2:第 1 部分第 6 课 原文:medium.com/hiromi_suenaga/deep-learning-2-part-1-lesson-6-de70d626976c 译者:飞龙 协议:CC BY-NC-SA 4.0 来自 fast.ai 课程的个人笔记。随着我继续复习课程以“真正”理解它,这…

监控概述、安装zabbix、配置zabbixagent、添加被控端主机、常用监控指标、自定义监控项

监控概述 对服务的管理,不能仅限于可用性。 还需要服务可以安全、稳定、高效地运行。 监控的目的:早发现、早治疗。 被监控的资源类型: 公开数据:对外开放的,不需要认证即可获取的数据私有数据:对外不开…

DRF 分页器的使用

drf提供了三个内置分页器,根据前端需求选择使用。 全局配置 在配置文件中设置全局的分页方式,如: REST_FRAMEWORK {DEFAULT_PAGINATION_CLASS: rest_framework.pagination.PageNumberPagination,PAGE_SIZE: 100 # 每页数目 }也可通过继…

20240211作业

运算符 1、选择题 1.1、若有以下程序 main(){ Char a1,b2; printf("%c,",b); printf("%d\n",b-a); } 程序运行后的输出结果是 A)3,2 B)50,2 C)2,2 D)2,50 1.2、有以下程序 main(){ i…

python coding with ChatGPT 打卡第20天| 二叉搜索树:搜索、验证、最小绝对差、众数

相关推荐 python coding with ChatGPT 打卡第12天| 二叉树:理论基础 python coding with ChatGPT 打卡第13天| 二叉树的深度优先遍历 python coding with ChatGPT 打卡第14天| 二叉树的广度优先遍历 python coding with ChatGPT 打卡第15天| 二叉树:翻转…

开关灯(c++题解)

题目描述 假设有N盏灯(N为不大于5000的正整数),从1到N按顺序依次编号,初始时全部处于关闭状态;有M个人(M为不大于N的正整数)也从1到M依次编号。 第一个人(1号)将灯全部打开,第二个人(2号&…

(基于xml配置Aop)学习Spring的第十五天

一 . Spring Aop编程简介 再详细点 , 如下 二 . 基于xml配置Aop 解决proxy相关问题 解决问题开始用xml配置AOP 导入pom坐标 <dependency><groupId>org.aspectj</groupId><artifactId>aspectjweaver</artifactId><version>1.9.6</vers…

webpack5 常用插件使用

webpack5常用插件使用 1. CleanWebpackPlugin2. HtmlWebpackPlugin3. DefinePlugin4.CopyWebpackPlugin 1. CleanWebpackPlugin 问题&#xff1a;每次打包完都需要手动删除掉dist文件目录&#xff0c;使用CleanWebpackPlugin就可自动清除dist目录。作用&#xff1a;自动清除di…

【算法】排序详解(快速排序,堆排序,归并排序,插入排序,希尔排序,选择排序,冒泡排序)

目录 排序的概念&#xff1a; 排序算法的实现&#xff1a; 插入排序&#xff1a; 希尔排序&#xff1a; 选择排序&#xff1a; 堆排序&#xff1a; 冒泡排序&#xff1a; 快速排序&#xff1a; 快速排序的基本框架&#xff1a; 1.Hoare法 2. 挖坑法 3.前后指针法 快…

linux系统下vscode portable版本的c++/Cmake环境搭建001

linux系统下vscode portable版本的Cmake环境搭建 vscode portable 安装安装基本工具安装 build-essential安装 CMake final script code安装插件CMake Tools & cmakeC/C Extension Pack Testsettings,jsonCMakeLists.txt调试和运行工具 CG 目的&#xff1a;希望在获得一个新…

DolphinScheduler-3.2.0 集群搭建

本篇文章主要记录DolphinScheduler-3.2.0 集群部署流程。 注&#xff1a;参考文档&#xff1a; DolphinScheduler-3.2.0生产集群高可用搭建_dophinscheduler3.2.0 使用说明-CSDN博客文章浏览阅读1.1k次&#xff0c;点赞25次&#xff0c;收藏23次。DolphinScheduler-3.2.0生产…

svg基础(七)滤镜-feflood,feDisplacementMap 位置替换滤镜

1 feflood 此过滤器创建一个矩形&#xff0c;其中填充了指定的的颜色&#xff0c;应用了不透明度值。 1.1 语法 <feFlood x"" y"" width"" height"" flood-color"" flood-opacity""/>1.2 属性 x&#x…

【复现】泛微云桥 e-Bridge SQL注入漏洞_45

目录 一.概述 二 .漏洞影响 三.漏洞复现 1. 漏洞一&#xff1a; 四.修复建议&#xff1a; 五. 搜索语法&#xff1a; 六.免责声明 一.概述 泛微云桥&#xff08;e-Bridge&#xff09;是上海泛微公司在”互联网”的背景下研发的一款用于桥接互联网开放资源与企业信息化系…