es6 基础学习之Promise和async await的相关

ES6 中的 Promise

Promise 是 ES6 中引入的一个构造函数,用于处理异步操作。一个 Promise 对象代表一个还没有完成但预计将在未来完成的操作。

创建一个 Promise

一个 Promise 的基础语法如下:

javascript 复制代码
const myPromise = new Promise((resolve, reject) => {
  // 异步操作
  if (/* 操作成功 */) {
    resolve('Success');
  } else {
    reject('Error');
  }
});

使用 Promise

你可以使用 .then().catch() 方法来处理 Promise。

javascript 复制代码
myPromise
  .then((result) => {
    console.log(result); // 输出 'Success'
  })
  .catch((error) => {
    console.log(error); // 输出 'Error'
  });

链式调用

Promise 可以链式调用:

javascript 复制代码
Promise.resolve('Success')
  .then((result) => {
    return result + ' - Step 1';
  })
  .then((result) => {
    console.log(result); // 输出 'Success - Step 1'
  });

并行执行多个 Promise

使用 Promise.all

javascript 复制代码
const promise1 = Promise.resolve(1);
const promise2 = Promise.resolve(2);

Promise.all([promise1, promise2])
  .then((results) => {
    console.log(results); // 输出 [1, 2]
  });

ES8 中的 asyncawait

ES8(ECMAScript 2017)引入了 asyncawait 关键字,使异步代码更像同步代码。

使用 asyncawait

一个简单的例子:

javascript 复制代码
async function fetchData() {
  try {
    const response = await fetch('https://api.example.com/data');
    const data = await response.json();
    console.log(data);
  } catch (error) {
    console.log('Fetch failed:', error);
  }
}

在这个例子中,fetchData 函数前面有一个 async 关键字,表示这是一个异步函数。在异步函数内部,你可以使用 await 关键字等待一个 Promise 完成并返回其结果。

错误处理

使用 try/catch 结构进行错误处理。

javascript 复制代码
async function fetchData() {
  try {
    const response = await fetch('https://api.example.com/data');
    if (!response.ok) {
      throw new Error('Network response was not ok');
    }
    const data = await response.json();
    console.log(data);
  } catch (error) {
    console.log('Fetch failed:', error);
  }
}

并行执行多个异步操作

使用 Promise.allawait

javascript 复制代码
async function fetchData() {
  const [data1, data2] = await Promise.all([fetch('url1'), fetch('url2')]);
  // Do something with data1 and data2
}

Promiseasync/await 都是处理异步操作的强大工具。async/await 基于 Promise 实现,但提供了更直观、更易读的语法。希望这些信息能帮助你更好地理解和使用这些异步编程特性。

相关推荐
angerdream4 小时前
最新版vue3+TypeScript开发入门到实战教程之路由详解三
前端·javascript·vue.js
数据潜水员6 小时前
三层统计最小力度的四种方法
javascript·vue.js
英俊潇洒美少年7 小时前
Vue3 的 JSX 函数组件,每次更新都会重新运行吗?
前端·javascript·vue.js
Irene19919 小时前
Vue3 响应式系统核心对比:effect, track, trigger,computed, watch, watchEffect
vue.js
saadiya~9 小时前
从插件冗余到极致流畅:我的 Vue 3 开发环境“瘦身”实录
前端·javascript·vue.js
慧一居士10 小时前
Zod 功能、使用场景介绍以及对应场景使用示例
前端·vue.js
Irene199110 小时前
Vue3 举例说明如何编写一个自定义组合式函数(与 Mixins 相比的优势)
vue.js
小马_xiaoen10 小时前
Vue 3 + TS 实战:手写 v-no-emoji 自定义指令,彻底禁止输入框表情符号!
前端·javascript·vue.js
Highcharts.js10 小时前
Highcharts Gantt 实战:从框架集成到高级功能应用-打造现代化、交互式项目进度管理图表
前端·javascript·vue.js·信息可视化·免费
终端鹿10 小时前
setup 语法糖从 0 到 1 实战教程
前端·javascript·vue.js