react-native – 类型错误:undefined不是对象(评估’style.width’)

前端之家收集整理的这篇文章主要介绍了react-native – 类型错误:undefined不是对象(评估’style.width’)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想把汽车图像放在背景图像上,就是这样.
import React,{ Component } from 'react';
import {
...
  Animated,ImageBackground
} from 'react-native';


export default class App extends Component {
  render() {
    return (
      <ImageBackground imageStyle={styles.container} source={require('./src/assets/img/road1.jpg')}>
       <Animated.Image style={styles.car} source={require('./src/assets/img/car2.png')}>
       </Animated.Image>
      </ImageBackground>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,position: 'relative',resizeMode: 'cover'
  },car:{
    position:'absolute',width:100,height:50
  }
});

当我运行此代码时,这是错误屏幕;

实际上信息是清楚的;

Type error:undefined is not an object(evaluating 'style.width')

好吧,但为什么它需要’style.width’,即使我使用resizeMode:’cover’
我还在样式对象中设置宽度和高度属性仍然是相同的错误..我该如何解决这个问题?

您的错误来自ImageBackground.js.

您正在为ImageBackground提供容器样式作为prop,它需要在那里存在宽度.

您通过无效的prop imageStyle提供样式.它应该作为样式提供

尝试:

<ImageBackground style={styles.container} source={require('./src/assets/img/road1.jpg')}>
       <Animated.Image style={styles.car} source={require('./src/assets/img/car2.png')}>
       </Animated.Image>
</ImageBackground>

猜你在找的React相关文章