• 2024-09-11鸿蒙里面处理异步函数的方法
    1.使用then()方法是用于处理异步操作成功后的结果,并且可以链式调用以实现多个异步操作的顺序执行.then()处理初始Promise的结果,然后返回一个新的值,这个新值被传递给下一个.then(),以此类推错误处理:如果在.then()中的函数抛出错误,这个错误会被传递给下一个.then()的on
  • 2024-09-11给你一个promise数组,我需要并行执行,并且数组里面所有promise全部抛出错误之后,才抛出错误,该怎么做
    今天面试,遇到如标题这么一个问题,真的给我问懵逼了,一开始想说使用promise.all,但是不行,因为promise.all只要有一个抛出错误了,整个promise.all就全部失败了。当时给我问的支支吾吾的打答不出来,并且还需要并行执行,想破头了都想不出来。后面回来重新学习ECMAScript才发现,使用一个API,pro
  • 2024-09-10在Vue 3中优化异步数据加载:利用`onMounted`与`Promise.all`
    在Vue3中优化异步数据加载:利用onMounted与Promise.all在构建现代Web应用时,异步数据加载是不可或缺的一部分。Vue3的CompositionAPI通过提供onMounted生命周期钩子和Promise.all方法,为我们提供了一种高效且优雅的方式来处理这种需求。本文将深入探讨如何在Vue3中利用这
  • 2024-09-10js中【微任务】和【宏任务】长篇解读
    在JavaScript中,理解微任务(microtasks)和宏任务(macrotasks)是掌握异步编程和事件循环(EventLoop)机制的关键。这两个概念影响了代码的执行顺序,特别是在涉及异步操作(如setTimeout、Promise、async/await等)时。为了深刻理解它们的差异及其在事件循环中的表现,我们将从最基
  • 2024-09-10需求:多个接口同时调用,全部完成后才能继续后续的逻辑(promise.all)
    前景提要:async/awiat的使用规则:   async表示这是一个async函数,await只能用在async函数里面,不能单独使用(await并不是必须要写的)   async返回的是一个Promise对象,await就是等待这个promise的返回结果后,再继续执行   await等待的是一个Promise对象,后面必须跟一个Pr
  • 2024-09-10js中【异步编程】超详细解读,看这一篇就够了
    一、JavaScript异步编程概述JavaScript是一门单线程语言,这意味着它同一时间只能执行一个任务。在现代Web开发中,异步编程变得尤为重要,因为许多任务(如网络请求、文件读取、定时器等)需要大量时间,如果使用同步编程模型,这些任务会阻塞整个线程,导致页面或程序卡顿。为了解决这个
  • 2024-09-08面试必备:从源码解析 Promise 方法的核心实现
    前言手写Promise相关经常是各大公司手撕代码环节会被问到的问题,本文手把手带你实现一遍Promise的核心功能和方法。基础功能实现consttest=newPromise((reslove,reject)=>{reslove("siu");});test.then((res)=>{console.log(res);
  • 2024-09-07js逆向基础14异步编程3
    上节课遗留.finally.finally()方法不管Promise对象最后的状态如何都会执行.finally()方法的回调函数不接收任何的参数,也就是你在.finally()函数中是没法知道Promise最终的状态是resolved还是rejected的它最终返回的默认会是一个上一次的Promise对象值,不过抛出的是一个异常
  • 2024-09-07promise
    手写promise--核心功能-->方法-->promise/A+参考mdn--promise..promise中的核心功能构造函数/***构造函数*1.定义类*2.添加构造函数*3.定义resolve/reject*4.执行回调函数*/classmyPromise{constructor
  • 2024-09-07Promise resolve reject 一直不执行会不会导致内存泄漏
    如果一个Promise一直不resolve或reject,它本身不会直接导致内存泄漏。这是因为Promise对象在其状态变为fulfilled(已解决)或rejected(已拒绝)之后就会变成不可变的状态,并且Promise本身并不会持有对大量数据的引用。然而,有几个方面需要注意:事件监听器和定时器:如果Pr
  • 2024-09-04尚硅谷前端 ES6 笔记
    ECMAScript6-11概述1.ECMA介绍ECMA(EuropeanComputerManufacturersAssociation)是欧洲计算机制造商协会,目标是评估、开发和认可电信和计算机标准。1994年后改名为Ecma国际。2.ECMAScript是什么ECMAScript是由Ecma国际通过ECMA-262标准化的脚本程序设计语言。3.
  • 2024-09-04Chaper 09 深入理解Promise
    欢迎大家订阅【Vue2+Vue3】入门到实践专栏,开启你的Vue学习之旅!文章目录前言一、异步编程二、Promise前言在JavaScript中,异步编程是一个重要的概念。随着应用程序的复杂性增加,处理异步操作的方式也变得更加复杂。Promise是一种用于处理异步操作的对象,它提供了
  • 2024-09-04promise实现一个动态删减并持续执行的队列
     promiseQueue.js:/**@Author:Simoon.jia*@Date:2024-09-0416:00:24*@LastEditors:Simoon.jia*@LastEditTime:2024-09-0416:55:48*@Description:描述*/exportclassPromiseQueue{constructor(){this.queue=[];this.isProcessing=
  • 2024-08-25九、前端中的异步方法Promise,Promise详解
    文章目录1.Promise简介什么是promise为什么使用Promisepromise中的状态2.Promis的用法1.Promise简介什么是promisePromise是异步编程的一种解决方案,它的构造函数是同步执行的,then方法是异步执行的。为什么使用Promise在JavaScript的世界中,所有代码都是单线程执
  • 2024-08-21Promise.all()
    Promise.all()是JavaScript中的一个内置方法,它接受一个Promise可迭代对象,并返回一个新的Promise。这个新Promise仅在可迭代对象中的所有Promise都已成功时才会被满足,或者在可迭代对象中的任何Promise被拒绝时立即被拒绝。Promise.all()的Promise的值是可迭代对象中
  • 2024-08-19【前端】使用Promise达到循环调用接口的效果
    Promise.all()要使用Promise.all调用同一个异步方法多次并将所有结果收集起来,你可以创建一个包含该方法调用的Promise数组,然后将这个数组传递给Promise.all。示例:假设你有一个异步方法fetchData(id),你想针对一组ID调用它并等待所有结果。asyncfunctionfetchData(id){
  • 2024-08-18函数回调地狱 + 解决方法(详解)
    概念需求:展示默认第一个省,第一个城市,第一个地区在下拉菜单中概念:在回调函数中嵌套回调函数,一直嵌套下去就形成了回调函数地狱 缺点:可读性差,异常无法捕获,耦合性严重,牵一发动全身问:1.什么是回调地狱?答案:在回调函数一直向下嵌套回调函数,形成回调函数地狱2.回调函数地
  • 2024-08-17手写Promise
    实现功能如下:Promise构造函数promise实例then方法pomise实例catch方法promise实例finally方法Promise静态resolve方法Promise静态reject方法Promise静态all方法备注:参照渡一教育视频代码:1constPending='pending';2constFullFiled='fulfilled';3con
  • 2024-08-17直播app开发,想实现并发控制看这里
    直播app开发,想实现并发控制看这里并发控制的概念相信大家都非常熟悉,比如浏览器请求的并发控制等。今天,我们结合async-pool这个开源工具来看看如何在直播app开发时,实现一个简单的并发控制。async-pool的代码分为es6和es7两个版本,都非常简单,我们主要基于es6版本进行
  • 2024-08-16lua版promise实现 - 结束
    相比V1版本这边做了以下修改:1)函数命名尽量与js版保持一致,js中的then在这边叫Next(因为then是lua的关键字)2)m_DoNextObj这边变成了一个列表,这样改动的结果就是:之前对象间会组成单向链表;这边是一个单向的树。3)m_DoNextObj.run函数这边改成了m_OnFulfilled和m_OnRejected函数(
  • 2024-08-16lua版promise实现3 - 条件判断例子
    针对:先加载资源A,加载完A再加载资源B,加载完B再加载资源C。现在加需求了,如果加载资源A的时间不超过3s,那说明当前设备性能不错,会额外再加载高品质资源A2,A3,然后再加载B。 localobj1=PromiseV1.new()localtime1=os.time()AsyncLoadRes("ResA",function(textA)obj1:S
  • 2024-08-15js异步之Promise使用
    Promise是异步编程的一种解决方案,是一个对象,可以获取异步操作的消息,大大改善了异步编程的困难,避免了回调地狱,比传统的解决方案回调函数和事件更合理和更强大。从语法上讲,Promise是一个对象,它可以获取异步操作的消息。提供了一个统一的API,各种异步操作都可以用同样的方法进行处理
  • 2024-08-14lua版promise实现 - 从异步回调多层嵌套开始
    异步回调代码,很容易就写出下面这样的不断嵌套的代码。如果还夹杂着各种逻辑的话,可读性会很差,还容易出错。AsyncLoadRes("ResA",function(textA)print("ResAloadfinish")AsyncLoadRes("ResB",function(textB)print("ResBloadfinish")AsyncLoad
  • 2024-08-13JavaScript 中的宏任务与微任务
    JavaScript是一种单线程的编程语言,这意味着在同一时间只能执行一个任务。为了有效地处理并发操作,JavaScript引入了事件循环(EventLoop)机制,其中宏任务(MacroTask)和微任务(MicroTask)在其中扮演着关键角色。1.什么是宏任务和微任务?宏任务(MacroTask)是JavaScript中执行的大
  • 2024-08-12JS Promise 一分钟带你深度理解
    JSPromise一分钟带你深度理解文章目录JSPromise一分钟带你深度理解一、什么是Promise?二、为什么使用Promise?三、基础知识四、创建Promise五、Promise使用1、链式调用2、顺序执行3、处理多个Promise4、错误处理六、高级用法七、最佳实践八