当前位置: 首页 > news >正文

做公司的网站有哪些东西吗html5网站欣赏

做公司的网站有哪些东西吗,html5网站欣赏,行者seo,网络公司如何建网站难点图解:then()方法 ES6学习网站:ES6 入门教程 解决:回调地狱(回调函数中嵌套回调) 两个特点: (1)对象的状态不受外界影响。Promise对象代表一个异步操作&…

 难点图解:then()方法

a01d447934ca4ffda2be39503b3a53ed.png

ES6学习网站:ES6 入门教程

解决:回调地狱(回调函数中嵌套回调)

两个特点:

(1)对象的状态不受外界影响。Promise对象代表一个异步操作,有三种状态:pending(进行中)、fulfilled(已成功)和rejected(已失败)。只有异步操作的结果,可以决定当前是哪一种状态,任何其他操作都无法改变这个状态。

(2)一旦状态改变,就不会再变,任何时候都可以得到这个结果Promise对象的状态改变,只有两种可能:从pending变为fulfilled和从pending变为rejected。只要这两种情况发生,状态就凝固了,不会再变了,会一直保持这个结果,这时就称为 resolved(已定型)。如果改变已经发生了,你再对Promise对象添加回调函数,也会立即得到这个结果。这与事件(Event)完全不同,事件的特点是,如果你错过了它,再去监听,是得不到结果的。

创建 Promise

你可以使用 new Promise() 构造函数来创建一个 Promise。它接受一个带有 resolvereject 两个参数的函数,这个函数会在异步操作完成(成功或失败)时被调用。

let myPromise = new Promise((resolve, reject) => {
  // 异步操作
  setTimeout(() => {
    let success = true;
    if (success) {
      resolve("操作成功!"); // 成功时调用 resolve,状态fulfill且改变当前promise对象的结果
    } else {
      reject("操作失败!"); // 失败时调用 reject
    }
  }, 2000); // 模拟2秒延迟
});

  Promise原型的方法

then()

p.then(value)=>{console.log('value')},成功调用时执行,resolve()类似声明,将形参传给then()方法

在then()方法的参数函数中,通过形参使用promise对象的结果

如果promise的状态不改变,then()里的方法不会执行

使用return会将当前promise实例的状态改成fulfilled,return返回值将作为形参传给下一个then()

如果当前then()中代码出错,会将promise实例的状态改成rejected
53b4f135c03e44deb2c486e89051026d.png

3ed262dd936c49878cb587cb1ea2499a.png

catch()

catch(),失败调用时执行

何时触发?reject()或者Promise执行体中有错

处理 Promise

使用 then() 方法来处理 Promise 对象的成功完成情况,并使用 catch() 方法来处理失败情况。

myPromise.then((message) => {
  console.log("成功:", message); // Promise 被 resolve 时执行
}).catch((error) => {
  console.error("错误:", error); // Promise 被 reject 时执行
});

 上边说到Promise是一个构造函数,new之后等于说调用了构造函数,构造函数中传的参数是一个函数,这个函数内的两个参数分别又是两个函数(reslovereject)

Promise 链 

Promise 可以通过链式调用进一步简化处理多个异步操作的代码。在 then() 方法中返回一个新的 Promise对象状态为pending,可以使得链式调用变得更加清晰。

// 假设有一个函数 fetchUserData 返回一个 Promise,用于获取用户数据
fetchUserData()
  .then((userData) => {
    // 处理获取到的用户数据
    return fetchUserPosts(userData.userId); // 返回另一个 Promise
  })
  .then((userPosts) => {
    // 处理获取到的用户发帖数据
  })
  .catch((error) => {
    console.error("处理过程中出现错误:", error);
  });

 Promise.all 

Promise.all() 用于同时处理多个 Promise,并在所有 Promise 都成功时返回一个包含所有结果的 Promise,但只要有一个 Promise 失败,它就会立即返回失败

let promise1 = someAsyncOperation();
let promise2 = anotherAsyncOperation();

Promise.all([promise1, promise2])
  .then((results) => {
    // results 包含了两个 Promise 的结果
  })
  .catch((error) => {
    // 处理失败情况
  });

Promise.race

 Promise.race() 用于竞争多个 Promise,返回一个新的 Promise,其结果由最先完成的 Promise 决定

let promise1 = fetchUserData();
let promise2 = new Promise((resolve, reject) => {
  setTimeout(() => {
    reject("操作超时!");
  }, 500); // 模拟超时操作
});

Promise.race([promise1, promise2])
  .then((result) => {
    // 处理最先完成的 Promise 的结果
  })
  .catch((error) => {
    // 处理失败情况,可能是超时或其他原因
  });

 

 

 

http://www.yayakq.cn/news/835030/

相关文章:

  • 可以做很多个网站然后哭推广大连短视频运营
  • 做网站一般注册哪几类商标有限公司注册资金
  • 深圳专业网站建设公司好吗用什么做公司宣传网站
  • 建成网站的关键是wordpress商城微信
  • ssh做的大型网站网络营销有哪些特点及功能
  • 点评网站建设制作网站站用的软件下载
  • 深圳品牌网站制作公司动漫网页设计作品
  • 西青集团网站建设南阳谁会做网站
  • 辽宁建设工程信息网官网新网站是哪个网站服务器好
  • 有什么网站可以免费看电影汕头潮南网站建设
  • 大作设计网站官网登录短网址在线生成短网址
  • wordpress仿站插件企业做推广有用吗
  • 做网站后台搭建都用什么上海网站建设品
  • 商务网站建设调研wordpress与微信小程序
  • 滨州内做网站系统的公司网页制作的目的
  • 网站推广的方式包括seo综合查询 站长工具
  • 域名注册网站建设一个平台怎么推广
  • 在国外做外国的网站合法吗炉石卡牌制作网页
  • 网站开发需要经历哪些主要阶段网站备案期间可以做推广吗
  • 制作社交网站网页开发者模式快捷键
  • 做网站那个公司wordpress免费手机主题
  • 做网站英文编辑有前途吗seo扣费系统源码
  • 怎么做黑彩黑彩网站房屋装修案例
  • 镇江网站制作价格怎么给网站加友情链接
  • 沂水县住房和建设局网站海外免备案网站
  • 一条龙网站建设哪家专业爱前端主图wordpress
  • 网站开发 兼容模式广东省建设行业数据开放平台
  • wordpress建站费用国外汽车配件网站模板
  • wordpress 支付 API橘子seo查询
  • 怎么做监控直播网站生物医药网站建设