Реагировать на встроенный поиск при изменении текста, структуры кода - PullRequest
0 голосов
/ 19 сентября 2019

Я создаю панель поиска, всякий раз, когда я выполняю поиск, я получаю неопределенную ошибку, потому что значение не существует в состоянии, пока я не завершу все значение, поэтому я знаю, что получу ошибку, но не могу ее решить, поэтому япытаясь отрисовать карточки в соответствии с поисковым вводом, я думаю, что я жестко запрограммировал мой homeScreen. Я не уверен, правильно ли я делаю это, и здесь возникает вопрос к трем, если утверждения внутри меня отдают, является ли это хорошей практикой?это профессионально?Могу ли я сделать что-то еще, что делает код легче читать и короче?Я думал об устранении третьего, если, но я не смог изменить состояние внутри второго, если так, поэтому мне пришлось добавить функцию поиска с переключателем, чтобы она работала с любыми идеями о том, как удалить третий, если было бы неплохо ...!заранее спасибо ребята

homeScreen.js

import axios from 'axios';
import React from 'react';
import {
  ActivityIndicator,
  ScrollView,
  Text,
  View,
  TouchableOpacity,
  TextInput,
} from 'react-native';
import Card from '../Components/Card/card';
export default class HomeScreen extends React.Component {
  state = {
    shows: [],
    isLoading: true,
    search: false,
    title: '',
  };

  componentDidMount() {
    this.getData();
  }
  toggleSearch = () => {
    console.log('hlelleloe');

    this.setState({
      search: true,
    });
  };
  getData = () => {
    const requestUrls = Array.from({length: 9}).map(
      (_, idx) => `http://api.tvmaze.com/shows/${idx + 1}`,
    );

    const handleResponse = data => {
      this.setState({
        isLoading: false,
        shows: data,
      });
    };
    const handleError = error => {
      console.log(error);
      this.setState({
        isLoading: false,
      });
    };

    Promise.all(requestUrls.map(url => axios.get(url)))
      .then(handleResponse)
      .catch(handleError);
  };

  render() {
    const {isLoading, shows, search, title} = this.state;
    if (isLoading) {
      return <ActivityIndicator size="large" color="#0000ff" />;
    } else if (!search) {
      return (
        <View>
          <View>
            <TouchableOpacity
              onPress={this.toggleSearch}
              style={{height: 300, width: 300}}>
              <Text style={{textAlign: 'center', fontSize: 40}}>
                Press to Search
              </Text>
            </TouchableOpacity>
          </View>
          <ScrollView style={{backgroundColor: '#E1E8E7'}}>
            {shows.length &&
              shows.map((show, index) => {
                return (
                  <Card
                    key={show.data.id}
                    title={show.data.name}
                    rating={show.data.rating.average}
                    source={show.data.image.medium}
                    genres={show.data.genres}
                    language={show.data.language}
                    network={show.data.network}
                    schedule={show.data.schedule}
                    summary={show.data.summary}
                    navigation={this.props.navigation}
                  />
                );
              })}
          </ScrollView>
        </View>
      );
    } else if (search) {
      console.log(title);

      return (
        <View>
          <TextInput
            style={{
              height: 100,
              width: 100,
              borderColor: 'gray',
              borderWidth: 1,
            }}
            onChangeText={searchedTitle => (
              <Card title={shows.data.searchedTitle} />
            )}
          />
        </View>
      );
    }
  }
}

Card.js

import React from 'react';
import {
  Image,
  View,
  Text,
  Button,
  StyleSheet,
  TouchableOpacity,
} from 'react-native';
import {
  widthPercentageToDP as wp,
  heightPercentageToDP as hp,
} from 'react-native-responsive-screen';
import Icon from 'react-native-vector-icons/FontAwesome';

const Card = props => {
  return (
    <View style={styles.container}>
      <Image style={styles.Image} source={{uri: `${props.source}`}} />
      <Text style={styles.title}>{props.title}</Text>
      <View style={styles.ratingContainer}>
        <Text style={styles.rating}>Rating: {props.rating}</Text>
        <Icon name="star" size={30} color="grey" />
      </View>
      <TouchableOpacity
        style={styles.button}
        onPress={() => {
          props.navigation.navigate('Details', {
            title: props.title,
            rating: props.rating,
            source: props.source,
            genres: props.genres,
            language: props.language,
            network: props.network,
            schedule: props.schedule,
            summary: props.summary,
          });
        }}>
        <Text style={styles.buttonText}>Press for details </Text>
      </TouchableOpacity>
    </View>
  );
};

export default Card;

const styles = StyleSheet.create({
  container: {
    flex: 1,
    alignItems: 'center',
  },
  Image: {
    flex: -1,
    width: wp('90%'),
    height: hp('65%'),
  },
  title: {
    flex: 1,
    fontSize: 40,
    borderRadius: 10,
    color: '#3C948B',
    margin: 15,
    justifyContent: 'center',
    alignItems: 'center',
  },
  ratingContainer: {
    flexDirection: 'row',
    alignItems: 'center',
    backgroundColor: 'white',
    elevation: 6,
    justifyContent: 'space-between',
    borderWidth: 1,
    width: 300,
  },
  rating: {
    fontSize: 25,
    paddingLeft: 15,
  },
  button: {
    flex: 1,
    color: '#3C948B',
    backgroundColor: '#3C948B',
    height: hp('7%'),
    width: wp('70%'),
    margin: 20,
    alignItems: 'center',
    borderBottomLeftRadius: 10,
    borderTopRightRadius: 10,
  },
  buttonText: {
    flex: 1,
    fontSize: 25,
  },
});

1 Ответ

0 голосов
/ 19 сентября 2019

Вам нужно реализовать конструктор для вашего компонента React.Как правило, конструкторы в React используются только для двух целей:

  • Инициализация локального состояния путем присвоения объекта this.state
  • Привязка методов-обработчиков событий к экземпляру

Do

state = {
 shows: [],
 isLoading: true,
 search: false,
 title: '',
};

заменить это на

constructor(props){
  super(props);
  this.state = {
    shows: [],
    isLoading: true,
    search: false,
    title: '',
  };
}
...