0

48小时过去了,还是没搞清楚。

我正在处理使用 Clarifai api 进行本机反应的承诺。这是我的代码:

function updater(){
      return ClarifaiApp.models.predict("coiner app", "https://www.coinsonline.com/wp-content/uploads/2015/11/Half-Dimes-and-Dimes.jpg").then(

        function(response){
          par1 = response['outputs'][0]['data']['concepts'][0];

          return (par1.name);
        });
     }

export default class CameraScreen extends React.Component {
 render(){
  return(
   function updater2(){
    updater().then(function(getAlll){
     <Text> {getAlll} </Text> //error: trying to add an object - invalid
    });
   );
  }
 }

现在,问题是我想获得“par1”的值。问题是,每当我尝试在控制台中获取 getAllll 的值为 par1 时,我都可以获得我想要的字符串,但是当我尝试将其添加为文本中的 {variable} 时,它会给出我正在尝试的错误里面的一个物体。

4

1 回答 1

0

我认为问题在于您正在尝试在渲染中渲染 Promise。我认为这个信息可能有点误导。这是一个 codepen,它解释了一种处理依赖于异步数据的渲染的方法。

https://codepen.io/sscaff1/pen/bMVvgN

export default class CameraScreen extends React.Component {
 state = { getAll: null }
 componentDidMount() {
   updater().then(getAll => this.setState({ getAll }));
 }
 render(){
  const { getAll } = this.state;
  return getAll ? <Text>{getAll}</Text> : null // you can also put a loader here
  }
 }
于 2018-04-22T14:55:43.907 回答