首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法使用react-native-snap-carousel

无法使用react-native-snap-carousel
EN

Stack Overflow用户
提问于 2018-08-21 16:34:53
回答 1查看 8.6K关注 0票数 2

我想使用react-native-snap-carousel,但是当我尝试init in时,我有一个错误:(

下面是一个例子:

代码语言:javascript
复制
import Carousel from 'react-native-snap-carousel';

export class MyCarousel extends Component {

_renderItem ({item, index}) {
    return (
        <View style={styles.slide}>
            <Text style={styles.title}>{ item.title }</Text>
        </View>
    );
}

render () {
    return (
        <Carousel
          ref={(c) => { this._carousel = c; }}
          data={this.state.entries}
          renderItem={this._renderItem}
          sliderWidth={sliderWidth}
          itemWidth={itemWidth}
        />
    );
}}

我的代码:

代码语言:javascript
复制
import React from 'react';
import { StyleSheet, Text, View } from 'react-native';
import Carousel from 'react-native-snap-carousel';

export default class App extends React.Component {
 _renderItem ({item, index}) {
   return (
      <View style={styles.slide}>
          <Text style={styles.title}>{ item.title }</Text>
      </View>
);}
 render () {
   return (
    <Carousel
      ref={(c) => { this._carousel = c; }}
      data={this.state.entries}
      renderItem={this._renderItem}
      sliderWidth={150}
      itemWidth={100}
    />
); 
}} 
    const styles = StyleSheet.create({
     container: {
      flex: 1,
      backgroundColor: '#fff',
      alignItems: 'center',
      justifyContent: 'center',
   }});

在app.js react本机上使用相同的Screenshot

我看到了一个问题(和我一样) link to Github Issue

但不回答和问题很接近

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-21 16:56:09

正如截图所示,this.state.entriesnull

您必须初始化它:

代码语言:javascript
复制
export default class App extends React.Component {
  constructor() {
    super()
    this.state = {
      entries: [],
    }
  }
  _renderItem ({item, index}) {
    return (
      <View style={styles.slide}>
          <Text style={styles.title}>{ item.title }</Text>
      </View>
  );}

  render () {
    return (
      <Carousel
        ref={(c) => { this._carousel = c; }}
        data={this.state.entries}
        renderItem={this._renderItem}
        sliderWidth={150}
        itemWidth={100}
      />
 ); 
}}

在本例中,entries: []不会显示任何内容,因为其中没有对象。您可以使用所需的数据对其进行初始化:

代码语言:javascript
复制
entries: [
  { title: 'hello' },
  { title: 'world' },
]

顺便说一句,这个问题与插件本身无关,即使他们可以捕捉到它。

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

https://stackoverflow.com/questions/51944706

复制
相关文章

相似问题

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