Реактивные нативные компоненты не перерисовываются при смене реквизита - PullRequest
0 голосов
/ 01 февраля 2020

Не обновлен мой компонент, если реквизиты изменены, но отправленное действие правильное, а Хранилище корректно обновлено . Реагировать на методы жизненного цикла без прослушивания реквизитов.

Только тогда повторно визуализировать компонент, если состояние изменилось. Но shouldComponentUpdate (), getDerivedStateFromProps () и componentDidUpdate () не реализовали изменение реквизитов.

Каким образом можно выполнить повторную визуализацию компонента, если реквизиты изменены?

Компонент:

import React, { Component } from 'react';
import { StyleSheet, View, Text, TextInput, TouchableOpacity } from 'react-native';

export default class Main extends Component {
    constructor(props) {
        super(props);
        this.state = {
            todos: []
        };
    }

    addTodo() {
        this.props.addTodo(this.state.title)
    }

    render() {
        return (
            <View>
                <Text style={style.title} >Alma</Text>
                <TextInput style={style.input} placeholder="New todo title" placeholderTextColor="gray" onChangeText={(text) => this.setState({ title: text })} />
                <TouchableOpacity style={{ margin: 20, backgroundColor: "lightblue", padding: 15, borderRadius: 20 }} onPress={() => this.addTodo()} >
                    <View>
                        <Text>Send</Text>
                    </View>
                </TouchableOpacity>

                {
                    this.props.todos.map((e, i) => {
                        return (
                            <Text style={{ textAlign: "center", fontSize: 17, margin: 10 }} key={i} >{e.title}</Text>
                        )
                    })
                }
            </View>
        );
    }
}

const style = StyleSheet.create({
    title: {
        textAlign: "center",
        marginTop: "20%",
        fontSize: 20
    },
    input: {
        borderColor: "black",
        borderWidth: 2,
        borderRadius: 20,
        paddingVertical: 10,
        paddingHorizontal: 20,
        color: "black"
    }
})
import { connect } from 'react-redux'
import { addTodo } from "./reducer";
import Main from "./Main";

function mapStateToProps(state, props) {
    return {
        todos: state.todos
    }
}

function mapDispatchToProps(dispatch, props) {
    return {
        addTodo: (text) => dispatch(addTodo(text))
    }
}

const MainContainer = connect(
    mapStateToProps,
    mapDispatchToProps
)(Main)

export default MainContainer;

Редуктор и действие:

export default function todoReducer(state = { todos: [] }, action) {
    if (action.type === 'ADD_TODO') {
        let currentState = state;
        currentState.todos.push(action.newTodo);

        return currentState;
    }

    return state
}

export function addTodo(title) {
    return {
        type: "ADD_TODO",
        newTodo: title
    }
}

и магазин:

import { createStore } from 'redux';
import todoReducer from "./reducer";
import { composeWithDevTools } from "redux-devtools-extension";


export default store = createStore(todoReducer,composeWithDevTools());

1 Ответ

0 голосов
/ 01 февраля 2020

Вы изменяете состояние в своем редукторе с помощью currentState.todos.pu sh (action.newTodo), это должна быть чистая функция, в противном случае реагирование не может знать, что реквизиты изменены.

Обновите свою функцию редуктора, чтобы она стала чистой функцией

export default function todoReducer(state = { todos: [] }, action) {
  if (action.type === 'ADD_TODO') {
    const todos = [...state.todos, action.newTodo];
    return {...state, todos };
  }

  return state;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...