在 Javascript 中将对象 Promise 转换为字符串
Posted
技术标签:
【中文标题】在 Javascript 中将对象 Promise 转换为字符串【英文标题】:Converting Object Promise to String in Javascript 【发布时间】:2018-12-17 09:54:44 【问题描述】:我正在使用 React、Next.Js、semantic-ui-react 和 Solidity。我的目标是打印出用户地址(来自 MetaMask)和 ProjectTitle(由用户设置)作为语义 UI 反应卡的元信息。打印“标题”中的地址是有效的,但我无法将 ProjectTitle 打印为“元”。标题应该是一个字符串,但我收到了一个对象承诺。
static async getInitialProps()
const projects = await factory.methods.getDeployedProjects().call();
return
projects
;
async getProjectTitle(address)
let title;
try
title = await factory.methods.projectTitle(address).call();
catch (err)
console.log('err');
return title;
renderProjects()
const items = this.props.projects.map(address =>
return
header: address,
color: 'green',
description: (
<Link route=`/projects/$address`>
<a>View Project</a>
</Link>
),
**meta: this.getProjectTitle(address)**,
fluid: true,
style: overflowWrap: 'break-word'
;
, );
return <Card.Group items=items />
Solidity 合约的一部分:
address[] public deployedProjects;
mapping(address => string) public projectTitle;
function createProject(string startup, string title, string deadline, string description, uint wage) public
address newProject = new Project(startup, title, deadline, description, wage, msg.sender);
projectTitle[newProject] = title;
deployedProjects.push(newProject);
function getDeployedProjects() public view returns (address[])
return (
deployedProjects
);
基本框架来自 Stephen Grider 的 Udemy 课程“以太坊和 Solidity:完整的开发者指南”。
【问题讨论】:
你不能“转换” Promise;您必须await
函数调用,否则显式使用 .then()
和回调函数。
好的,谢谢。这就是我所期待的答案。但这给我带来了另一个可能很简单的问题。我写了以下几行: var title = this.getProjectTitle(address).then(res => console.log('res', res); ); 'res' 带来类型 (字符串),我需要。但我不知道如何将变量转移到元标记。也许我今天有点慢。
您可以将 projectTitle 异步调用移到 return header: address, ... 对象之前,然后等待 promise 返回。在 thennable 中,您可以使用 setState() 或任何在 thennable 范围之外记录结果的组件函数。不利的一面是,这使得 map() 与等待这些承诺的结果一一同步。更好的方法是使用新的 Promise.all() 并在初始渲染/挂载时获取项目名称,具体取决于它是函数还是 React.Component。
【参考方案1】:
没有直接的方法可以将 Object Promise 转换为 String。
继续处理的唯一方法是调用await
函数或使用.then()
和回调函数。
【讨论】:
以上是关于在 Javascript 中将对象 Promise 转换为字符串的主要内容,如果未能解决你的问题,请参考以下文章
在 Javascript 中将多个 Promise 推入数组时处理单个错误
在 Vue 3 中将数据对象设置为来自 Promise 的值