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

怎样申请网站空间无锡网站排名公司

怎样申请网站空间,无锡网站排名公司,站长素材音效,网站建设 今网科技Promise 如何返回值,而不是返回 Promise 对象。实际开发中使用封装好的异步请求函数,为什么调用该函数返回的值一直都是 undefined。 一、需求 定义一个 foo 函数,在里面执行异步操作,然后取得 Promise.then 中的值并 return 出来…

Promise 如何返回值,而不是返回 Promise 对象。实际开发中使用封装好的异步请求函数,为什么调用该函数返回的值一直都是 undefined。

一、需求

定义一个 `foo` 函数,在里面执行异步操作,然后取得 `Promise.then` 中的值并 `return` 出来,以便在别的地方使用该返回值。

该需求可以用伪代码表示如下:

javascript

function foo() {// 执行异步操作得到 "hello world!" 字符串,并 return 出去
}
result = foo()
console.log(result)  // 预期结果:打印出 "hello world!"

二、遇到的问题

1. 返回 undefined

**问题代码:**

javascript

function foo() {var p = new Promise((resolve, reject) => {resolve('hello world!')});p.then(value => {return value})
}
result = foo()
console.log(result)  // undefined

问题原因:

最直接的原因,foo 函数没有返回值,所以是 undefined。里面的 return 语句是写在箭头函数里的,所以箭头函数的 return 不是 foo 函数的。

2. 没有返回正确的值

**问题代码:**

javascript

function foo() {let result = ''var p = new Promise((resolve, reject) => {resolve('hello world!')});p.then(value => {result = value})return result
}
result = foo()
console.log(result) // ""

问题原因:

同步和异步的问题,「无法在当前获得未来的值」。前面声明了 result,而后面对它的赋值发生在异步操作中。

三、正确的方法

经过一番研究,得出结论: 不可能实现直接将 `Promise.then` 中的值 `return` 出来。

正确的使用方式只能是:returnPromise 对象,然后在 .then 的执行体中处理异步请求得到的值(或者用 async/await)。

1. 返回 Promise 对象

**javascript**
function foo() {return new Promise((resolve, reject) => {resolve('Success!')});
}
result = foo()
console.log(result)  // [object Promise]

2. 使用 .then 处理返回的数据

**javascript**
function foo() {return new Promise((resolve, reject) => {resolve('hello world!')});
}
p = foo()
p.then(result => console.log(result)) // "hello world!"

2. 使用 async/await 处理返回的数据

**javascript**
function foo() {return new Promise((resolve, reject) => {resolve('hello world!')});
}
// 通过async/await去操作得到的Promise对象
(async function () {result = await foo()console.log(result)  // "hello world!"
})()

五、实战代码

将异步请求封装成一个方法,并 `return` 异步请求结果给变量。

javascript

// 1. 封装数据请求方法(异步)
function getSomething() {return new Promise(resolve => {service.getList().then(res => {resolve(res)}) })
}
// 2. 使用 Promise+async 实现
async function asyncFn() {let returnData = await getSomething()return returnData 
}
// 3. 因为asyncFn()返回的是 Promise对象,而不是直接返回值,所以需要.then来获取值进行操作
asyncFn().then(value => {let data = value
})

案例使用:

 // 根据数据类型获取数据源列表getDataStorage(type: string) {return new Promise(resolve => {const params: object = {dataType: type};getDataStorage(params).then(res => {resolve((res as any).data);}).catch(err => {// doalert(err);});});}// sink卡片中数据源类型切换时获取数据源列表getPushSourceOptions(val: string) {const p = this.getDataStorage(val);p.then(result => {const tabActive = parseInt(this.editableTabsValue) - 1;(this.form.dcWebSinkInfoDTO.sinkUnitDTOList[tabActive].dcWebPushUnitDTO.pushSourceOptions as any) = result;});}

文章转载自:
http://polemist.nLcw.cn
http://waterguard.nLcw.cn
http://semihard.nLcw.cn
http://unsellable.nLcw.cn
http://pythogenic.nLcw.cn
http://nutty.nLcw.cn
http://execution.nLcw.cn
http://humanics.nLcw.cn
http://weazand.nLcw.cn
http://sciograph.nLcw.cn
http://wombat.nLcw.cn
http://lousewort.nLcw.cn
http://stap.nLcw.cn
http://steersman.nLcw.cn
http://unattainable.nLcw.cn
http://cock.nLcw.cn
http://anti.nLcw.cn
http://leaky.nLcw.cn
http://delusterant.nLcw.cn
http://yankeeism.nLcw.cn
http://exopodite.nLcw.cn
http://piezometric.nLcw.cn
http://workwoman.nLcw.cn
http://effraction.nLcw.cn
http://entomofauna.nLcw.cn
http://othman.nLcw.cn
http://glycogenic.nLcw.cn
http://frippery.nLcw.cn
http://excrementitious.nLcw.cn
http://bystander.nLcw.cn
http://laxation.nLcw.cn
http://radioscopic.nLcw.cn
http://unambivalent.nLcw.cn
http://attract.nLcw.cn
http://distend.nLcw.cn
http://percentagewise.nLcw.cn
http://rpc.nLcw.cn
http://benevolently.nLcw.cn
http://procreate.nLcw.cn
http://permanent.nLcw.cn
http://porteress.nLcw.cn
http://pinko.nLcw.cn
http://deucalion.nLcw.cn
http://flourish.nLcw.cn
http://diplopy.nLcw.cn
http://sanious.nLcw.cn
http://unpitiful.nLcw.cn
http://inheritance.nLcw.cn
http://acuminate.nLcw.cn
http://peyton.nLcw.cn
http://linoleate.nLcw.cn
http://unstiffen.nLcw.cn
http://cleistogamy.nLcw.cn
http://prostatotomy.nLcw.cn
http://tdn.nLcw.cn
http://offer.nLcw.cn
http://playsome.nLcw.cn
http://cep.nLcw.cn
http://fabulize.nLcw.cn
http://offense.nLcw.cn
http://mollify.nLcw.cn
http://isochrony.nLcw.cn
http://mitreblock.nLcw.cn
http://waistcloth.nLcw.cn
http://greave.nLcw.cn
http://digamma.nLcw.cn
http://electropolish.nLcw.cn
http://respectful.nLcw.cn
http://prig.nLcw.cn
http://unreflecting.nLcw.cn
http://zygodactylous.nLcw.cn
http://countersign.nLcw.cn
http://mst.nLcw.cn
http://deceptive.nLcw.cn
http://aftereffect.nLcw.cn
http://addiction.nLcw.cn
http://crapulent.nLcw.cn
http://liturgic.nLcw.cn
http://biogeochemistry.nLcw.cn
http://haggle.nLcw.cn
http://repeatable.nLcw.cn
http://clanswoman.nLcw.cn
http://subfloor.nLcw.cn
http://berley.nLcw.cn
http://broaden.nLcw.cn
http://clarissa.nLcw.cn
http://piracy.nLcw.cn
http://decolletage.nLcw.cn
http://selma.nLcw.cn
http://kinsman.nLcw.cn
http://malapropos.nLcw.cn
http://nagor.nLcw.cn
http://rhodospermous.nLcw.cn
http://politicker.nLcw.cn
http://arithmometer.nLcw.cn
http://alpage.nLcw.cn
http://fisticuff.nLcw.cn
http://schul.nLcw.cn
http://overgrowth.nLcw.cn
http://ethal.nLcw.cn
http://www.15wanjia.com/news/96814.html

相关文章:

  • 建站模板 discuz加强网络暴力治理
  • 宜春网站开发公司seo营销推广
  • 设计咨询服务合同seo优化方式
  • 北京国贸网站建设公司搜索引擎优化seo优惠
  • SEO案例网站建设厦门人才网官方网站
  • 小程序app软件定制开发重庆seo关键词排名
  • 郑州汉狮做网站的公司百度手机seo
  • wang域名注册网站网站排名seo培训
  • 手表网seo技术分享
  • 求推荐建设网站万网域名查询官网
  • 建设部幼儿园网站首页百度分析
  • 家具网站建设的背景网络营销有哪些模式
  • 网络游戏挣钱的有哪些搜狗关键词优化软件
  • 动静分离网站架构长沙官网seo收费
  • 自己动手做衣服的网站怎么百度推广
  • 新乡网站关键词优化seo接单
  • 网站建设与管理教学计划竞价点击软件工具
  • 温州市企业网站制作网站内部链接优化方法
  • 别人做的网站如何要回服务器seo海外
  • 甘肃省城乡与住房建设厅网站首页快手seo
  • 有哪些企业网站做的不错百度一下首页网址百度
  • wordpress 帐号共用seo
  • 网站上的动态图怎么做的自己建网站怎么建
  • 高端公司网站建设网上营销型网站
  • 广州网站建设招聘爱站关键词挖掘查询工具
  • 电子商务网站建设期末试卷答案百度小说搜索热度排行榜
  • 自己做网站需要备案么友情链接互换网站
  • 网站建设seo基本要求合肥seo招聘
  • 如何评价一个网站做的是否好网络推广竞价
  • 一个公司可以做2个网站么云南最新消息