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 实现,但提供了更直观、更易读的语法。希望这些信息能帮助你更好地理解和使用这些异步编程特性。

相关推荐
一 乐2 小时前
旅游|基于springboot + vue旅游信息推荐系统(源码+数据库+文档)
java·vue.js·spring boot·论文·旅游·毕设·旅游信息推荐系统
最逗前端小白鼠3 小时前
vue3 数据响应式遇到的问题
前端·vue.js
卤蛋fg64 小时前
vxe-table 自定义数字行主键,解决默认字符串主键与后端类型不匹配问题
vue.js
岁月宁静4 小时前
都知道AI大模型能生成文本内容,那你知道大模型是怎样生成文本的吗?
前端·vue.js·人工智能
|晴 天|4 小时前
我如何用Vue 3打造一个现代化个人博客系统(性能提升52%)
前端·javascript·vue.js
yuqifang5 小时前
vue3+typescript+vite封装自己的UI组件库并上传至npm
vue.js·arkui
布局呆星5 小时前
Vue3 :生命周期、DOM 操作与自定义组合式函数
前端·javascript·vue.js
Ruihong6 小时前
你的 Vue 3 <script setup>,VuReact 会编译成完整的 React 组件
vue.js·react.js·面试
小李子呢02116 小时前
前端八股Vue---插槽
前端·javascript·vue.js
一 乐6 小时前
咖啡商城|基于springboot + vue咖啡商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·咖啡商城系统