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

enter image description here

Я делаю раздел комментариев, поэтому хочу скрыть область изображения, если изображение пустое и если источник изображения доступен, то показать содержание изображения и использованное условие, если, но все же проблема с изображением загружается, но проблема заключается в пробелах, как это исправить, пожалуйста, дайте мне знать, что я новичок в реагировании - родной

и использовал много ссылок, но все тот же вопрос

   import React, { Component } from 'react';
import {
  StyleSheet,
  Text,
  View,
  TouchableOpacity,
  Image,
  ScrollView,
  FlatList,
  BackHandler
} from 'react-native';
import { Container, Content, Icon, Header, Left, Body, Right, Segment, Button } from 'native-base'
import ImageLoad from 'react-native-image-placeholder';


export default class CommentScreen extends Component {

  constructor(props) {
    super(props);
    this.state = {
      data:[
        {id:1, image: "https://bootdey.com/img/Content/avatar/avatar1.png", name:"Frank Odalthh",    comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor." , ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
        {id:2, image: "https://bootdey.com/img/Content/avatar/avatar6.png", name:"John DoeLink",     comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor." , ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
        {id:3, image: "https://bootdey.com/img/Content/avatar/avatar7.png", name:"March SoulLaComa", comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
        {id:4, image: "https://bootdey.com/img/Content/avatar/avatar2.png", name:"Finn DoRemiFaso",  comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
        {id:5, image: "https://bootdey.com/img/Content/avatar/avatar3.png", name:"Maria More More",  comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
        {id:6, image: "https://bootdey.com/img/Content/avatar/avatar4.png", name:"Clark June Boom!", comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl: null },
        {id:7, image: "https://bootdey.com/img/Content/avatar/avatar5.png", name:"The googler",      comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl: null},
      ]
    }
  }
componentWillMount() {
    BackHandler.addEventListener('hardwareBackPress', this.backPressed);
}

componentWillUnmount() {
    BackHandler.removeEventListener('hardwareBackPress', this.backPressed);
}

backPressed = () => {
    this.props.navigation.navigate('App');
    return true;
}
   static navigationOptions = { header: null }

  render() {
    return (
      <FlatList
        style={styles.root}
        data={this.state.data}
        extraData={this.state}
        ItemSeparatorComponent={() => {
          return (
            <View style={styles.separator}/>
          )
        }}
        keyExtractor={(item)=>{
          return item.id.toString();
        }}
        renderItem={(item) => {
          const Notification = item.item;
          return(
            <View style={styles.container}>
              <TouchableOpacity onPress={() => {}}>
                <Image style={styles.image} source={{uri: Notification.image}}/>
              </TouchableOpacity>
              <View style={styles.content}>
                <View style={styles.contentHeader}>
                  <Text  style={styles.name}>{Notification.name}</Text>
                  <Text style={styles.time}>
                    9:58 am
                  </Text>
                </View>
                <Text rkType='primary3 mediumLine'>{Notification.comment}</Text> 
                <View>

            <ImageLoad style={{width:150, height:140}}  source={{uri: Notification.ImageUrl}}/>
</View>
              </View>
            </View>
          );
        }}/>
    );
  }
}

1 Ответ

0 голосов
/ 04 мая 2019

Вы можете использовать изображение по умолчанию с помощью свойства defaultSource или в случае отсутствия URL-адреса.

Или вы можете попробовать это, чтобы не отображать его:

{Notification.ImageUrl? <ImageLoad style={{width:150, height:140}}  source={{uri: Notification.ImageUrl}}/> : null}

при условии Notification.imageявляется нулевым, когда нет изображения.

EDITED ваш код с предложенным iv'e.обратите внимание, что есть комментарий и нет стиля.но это работает.ура

import React, { Component } from 'react';
import {
StyleSheet,
Text,
View,
TouchableOpacity,
Image,
ScrollView,
FlatList,
BackHandler
} from 'react-native';
// import { Container, Content, Icon, Header, Left, Body, Right, Segment, Button } from 'native-base'
import ImageLoad from 'react-native-image-placeholder';


export default class CommentScreen extends Component {

constructor(props) {
 super(props);
 this.state = {
   data:[
     {id:1, image: "https://bootdey.com/img/Content/avatar/avatar1.png", name:"Frank Odalthh",    comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor." , ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
     {id:2, image: "https://bootdey.com/img/Content/avatar/avatar6.png", name:"John DoeLink",     comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor." , ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
     {id:3, image: "https://bootdey.com/img/Content/avatar/avatar7.png", name:"March SoulLaComa", comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
     {id:4, image: "https://bootdey.com/img/Content/avatar/avatar2.png", name:"Finn DoRemiFaso",  comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
     {id:5, image: "https://bootdey.com/img/Content/avatar/avatar3.png", name:"Maria More More",  comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl:"https://lorempixel.com/400/200/nature/5/"},
     {id:6, image: "https://bootdey.com/img/Content/avatar/avatar4.png", name:"Clark June Boom!", comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl: null },
     {id:7, image: "https://bootdey.com/img/Content/avatar/avatar5.png", name:"The googler",      comment:"Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.",  ImageUrl: null},
   ]
 }
}
componentWillMount() {
 BackHandler.addEventListener('hardwareBackPress', this.backPressed);
}

componentWillUnmount() {
 BackHandler.removeEventListener('hardwareBackPress', this.backPressed);
}

backPressed = () => {
 this.props.navigation.navigate('App');
 return true;
}
static navigationOptions = { header: null }

render() {
 return (
   <FlatList
     style={styles.root}
     data={this.state.data}
     extraData={this.state}
     ItemSeparatorComponent={() => {
       return (
         <View style={styles.separator}/>
       )
     }}
     keyExtractor={(item)=>{
       return item.id.toString();
     }}
     renderItem={(item) => {
       const Notification = item.item;
       return(
         <View style={styles.container}>
           <TouchableOpacity onPress={() => {}}>
             <Image style={styles.image} source={{uri: Notification.image}}/>
           </TouchableOpacity>
           <View style={styles.content}>
             <View style={styles.contentHeader}>
               <Text  style={styles.name}>{Notification.name}</Text>
               <Text style={styles.time}>
                 9:58 am
               </Text>
             </View>
             <Text rkType='primary3 mediumLine'>{Notification.comment}</Text>
             <View>
             {Notification.ImageUrl? <ImageLoad style={{width:150, height:140}}  source={{uri: Notification.ImageUrl}}/>: null}

</View>
           </View>
         </View>
       );
     }}/>
 );
}
}

const styles = {};
...