FlatList Mobx ReactNative缺少用于计算的选项:获取

时间:2019-04-04 18:26:02

标签: react-native mobx react-native-flatlist mobx-react

当我单击“添加项目”按钮时,我看到日志中已添加项目,但视图未重新呈现。

我的商店:

import {observable, action, computed} from 'mobx';

export default class ObservableItemStore {
  @observable items = ["Item A", "Item B"];

  @computed get myItems() {
    return this.items;
  }

  @action addItem(item)) {
    console.log("Adding to" + this.items);
    this.items.push(item);
  }
}
import React, {Component} from 'react';
import {Button, FlatList, StyleSheet, Text, View} from 'react-native';
import { observer } from 'mobx-react';
import { Observer } from 'mobx-react/native';
import { Items } from '../../stores';
interface Props {}

@observer
class List extends Component<Props> {
  render() {
    return (
      <View style={styles.container}>
        <Button
          title="Add Item"
          onPress={() => {
            Items.addItem("Foo");
          }}
        />
        <Observer>{() => {
          return <FlatList
            data={ Items.items }
            renderItem={({item}) => <Text>{item}</Text>}
          />
        }}
        </Observer>
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
  welcome: {
    fontSize: 20,
    textAlign: 'center',
    margin: 10,
  },
  instructions: {
    textAlign: 'center',
    color: '#333333',
    marginBottom: 5,
  },
});

export default List;

为什么不重新渲染视图?

1 个答案:

答案 0 :(得分:0)

您应该在渲染器中使用数组属性之一(items.slice(),item.map(),item.length等)。

https://mobx.js.org/best/react.html#incorrect-use-an-observable-but-without-accessing-any-of-its-properties