前端面试之异步、单线程

一、异步和同步的区别

同步:
JS是单线程语言,只能同时做一件事儿。js任务需要排队顺序执行,如果一个任务时间过长,后边的任务也会等着。假如,我们在请求一个网址时,图片加载很慢,网页总不能一直卡不出来,这个时候就可以用异步来解决了。

异步:
异步就是由单线程这个背景而来的,解决了单线程等待的这个问题,异步的特点不会阻塞后面代码的执行。也就是请求处理过程中,你不能闲着,会产生异步的请求,回头再处理,然后继续执行下面的请求

异步和单线程是相辅相成的,js是一门单线程脚本语言,所以需要异步来辅助

二、前端使用异步的场景有哪些

网络请求,如ajax图片加载

//ajax
    console.log('satrt')
    $.get('./data1.json',function(data1){
        console.log(data1)
    })
    console.log('end')
    

定时任务,如setTimeout

// 异步执行(callback回调函数) Promise解决了callback异步的问题
    console.log(100)
    setTimeout(()=>{
        console.log(200)
    },1000)
    console.log(300) 
     // 100>300>200

三、使用Promise加载一张图片

function loadImg(src2) {
    return new Promise(
        //参数 resolve reject 均是函数
        (resolve,reject)=>{
            const img1 = document.createElement('image')
            img1.src = src2
            img1.onload=()=>{
                resolve(img1)
            }
            img1.onerror=()=>{
                const err = new Error(`图片加载失败!${src}`)
                reject(err)
            }
            
        }
    )
}
const url1 = 'https://img4.sycdn.imooc.com/szimg/5dbffa9109ef425a12000676-360-202.png'
const url2 = 'https://img4.sycdn.imooc.com/szimg/5dbffa9109ef425a12000676-360-202.png'
loadImg(url1).then(img=>{
    console.log(img.width)
    return img
}).then(img=>{
    console.log(img.height)
    return loadImg(url2)
}).then(img2=>{
    console.log(img2.width)
    return img2
}).then(img2=>{
    console.log(img2.height)
})
.catch(err=>{
    console.log(err)
})
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
前端开发中,我们经常会遇到需要处理异步操作的情况。异步操作是指不会阻塞代码执行的操作,例如发送网络请求、读取文件等。而同步操作则是会阻塞代码执行的操作。 为了解决异步操作带来的问题,我们可以使用回调函数、Promise、async/await等方式将异步代码转换为同步代码。 1. 回调函数:通过在异步操作完成后执行指定的回调函数来处理异步结果。例如: ```javascript function fetchData(callback) { setTimeout(function() { const data = '异步数据'; callback(data); }, 1000); } fetchData(function(data) { console.log(data); }); ``` 2. Promise:Promise 是一种用于处理异步操作的对象。它可以表示一个异步操作的最终完成或失败,并返回结果或错误信息。例如: ```javascript function fetchData() { return new Promise(function(resolve, reject) { setTimeout(function() { const data = '异步数据'; resolve(data); }, 1000); }); } fetchData().then(function(data) { console.log(data); }); ``` 3. async/await:async/await 是基于 Promise 的一种异步编程模型,使得异步代码看起来像同步代码,更易于理解和维护。例如: ```javascript function fetchData() { return new Promise(function(resolve, reject) { setTimeout(function() { const data = '异步数据'; resolve(data); }, 1000); }); } async function fetchDataAsync() { const data = await fetchData(); console.log(data); } fetchDataAsync(); ``` 这些是常见的解决异步操作的方式,根据具体需求和项目情况,选择合适的方式来处理异步操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只小 Ziyi.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值