首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在函数中的本机响应中迭代数组,并在render()方法中使用它。必须返回有效的React元素(或null)。

如何在函数中的本机响应中迭代数组,并在render()方法中使用它。必须返回有效的React元素(或null)。
EN

Stack Overflow用户
提问于 2017-08-28 17:25:46
回答 3查看 940关注 0票数 0

我是一个新的蜜蜂,以反应本土化,当我创建一个函数之外的渲染功能时,我无法使用地图渲染项目。

如果我提供正常的退货表,它可以工作:

代码语言:javascript
复制
function(props){
return <Text> Hello </Text>
}

但当我试图迭代时,它却没有。在下面的代码中,请告诉我函数函数Xyz(x)有什么问题。

代码语言:javascript
复制
    import React, { Component } from 'react';
import { AppRegistry, SectionList, StyleSheet, Text, View , Button} from 'react-native';
import { connect } from 'react-redux'


class SectionListBasics extends Component {

constructor(props){
  super(props);


}

data = {
     "data": {
       "driver": {
         "name": "Sangesh",
         "phone": "07453520814"
       },
       "store": [
         {
           "host": "s-447.t2scdn.com",
           "name": "DEV - s-447.t2scdn.com",
           "license_key": "123",
           "driver_id": "56769"
         },
         {
           "host": "s-519.t2scdn.com",
           "name": "DEV - s-519.t2scdn.com",
           "license_key": "345",
           "driver_id": "56815"
         }        

       ]
     }
   }



  render() {
    return (
        <View>
        <Xyz c={this.data}/>       

      </View>


    );
  }
}




function Xyz(x) {

      return (x.c.data.store.map((index) => { <Text> {index.host} </Text> }))

}


export default connect(mapStateToProps, mapDispatchToProps)(SectionListBasics)

自定义Xyz无法工作。

它不断地抛出以下错误:

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-08-28 18:04:54

我犯了个愚蠢的错误

工作代码

代码语言:javascript
复制
function Xyz(x) {
  return (
    <View>
      {x.c.data.store.map((item) => (<Text> {item.name} </Text>))}
    </View>
  )
}

错误代码(语法错误)

代码语言:javascript
复制
function Xyz(x) {
  return (
    <View>
      {x.c.data.store.map((item) => { <Text> {item.name} </Text> })}
    </View>
  )
}

这段代码应该包装在()中,而不是{} {<Text> {item.name} </Text>} -to-->> (<Text> {item.name} </Text>)

通过改变它是可行的。在这个{}它被视为jsx。同样重要的是,当返回时,它应该被包装在视图

票数 2
EN

Stack Overflow用户

发布于 2017-08-28 17:38:24

内部回报:

代码语言:javascript
复制
{
  someData.map((item) => (
    <Xyz
      key={itemId}
      custom={item.field}
    />
  ))
}
票数 0
EN

Stack Overflow用户

发布于 2017-08-28 17:40:31

您的数据不是一个对象,因此不能执行x.c.data.store.map(...)

首先尝试解析JSON,或者使用一个对象作为数据。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45924388

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档