【问题标题】:Image fixed inside the ScrollView with React native使用 React native 固定在 ScrollView 内的图像
【发布时间】:2016-01-21 23:08:48
【问题描述】:

我想在滚动视图组件内的专用视图上修复图像以及线性渐变。我尝试了一些样式,但每次,图像都会随着内容滚动。

我能做什么?

<ScrollView>
  {/* TODO: Prevent scroll for this View — Add blur image on background */}
  <View>
    <Image source={{ uri: cover_photo }} />
    <LinearGradient  />
  </View>

  {/* This view is scrollable ABOVE the background image */}
  <View>
     {…content}
  </View>
</ScrollView>

【问题讨论】:

    标签: javascript ios reactjs scrollview react-native


    【解决方案1】:

    为此,您将无法在 ScrollView 本身中设置 Image 或 LinearGradient。相反,您需要在 ScrollView 之外设置 Image 和 LinearGradient,并将它们都设置为 absolute 定位。

    然后,设置scrollView的子View的marginTop与图片的高度和LinearGradient一致。这是一个示例设置:

    var SampleApp = React.createClass({
    
      let LinearGradient = <View style={{ position:'absolute', top:0, left:0, width: width, height:width, backgroundColor: 'rgba(100, 97, 67, .7)' }} />
    
      render: function() {
        return (
          <View style={{ flex:1, backgroundColor: 'transparent' }}>
            <View>
              <Image style={{ height: width, width: width, position: 'absolute', top:0, left:0 }} source={{ uri: 'http://i01.i.aliimg.com/wsphoto/v0/32297951629_5/5pcs-lot-The-Hollowan-Star-Nicolas-Cage-Stylish-Square-Pillowcase-Cushion-Pillow-Cover.jpg' }} />
              { LinearGradient }
            </View>
            <ScrollView style={{ flex:1 }}>
              <View style={{ marginTop:320 }}>
                <Text>{content}</Text>
              </View>
            </ScrollView>
          </View>
        );
      }
    });
    

    有一个工作版本here

    https://rnplay.org/apps/PXNHyg

    如果您不希望 ScrollView 从顶部偏移,只需像 this 示例中那样删除 marginTop。

    https://rnplay.org/apps/-s97Gw

    完整代码如下:

    'use strict';
    
    var React = require('react-native');
    var {
      AppRegistry,
      StyleSheet,
      Text,
      View,
      Dimensions,
      ScrollView,
      Image
    } = React;
    
    let width = Dimensions.get('window').width
    
    var SampleApp = React.createClass({
    
      render: function() {
    
        let LinearGradient = <View style={{ position:'absolute', top:0, left:0, width: width, height:width, backgroundColor: 'rgba(100, 97, 67, .7)' }} />
    
        return (
          <View style={{ flex:1, backgroundColor: 'transparent' }}>
                <View>
                <Image style={{ height: width, width: width, position: 'absolute', top:0, left:0 }} source={{ uri: 'http://i01.i.aliimg.com/wsphoto/v0/32297951629_5/5pcs-lot-The-Hollowan-Star-Nicolas-Cage-Stylish-Square-Pillowcase-Cushion-Pillow-Cover.jpg' }} />
                        { LinearGradient }
              </View>
            <ScrollView style={{ flex:1 }}>
              <View style={{ marginTop:320 }}>
                                <Text>{ipsum}</Text>
              </View>
            </ScrollView>
          </View>
        );
      }
    });
    
    var styles = StyleSheet.create({
      container: {
        flex: 1,
        justifyContent: 'center',
        alignItems: 'center',
        backgroundColor: '#F5FCFF',
      },
      welcome: {
        fontSize: 28,
        textAlign: 'center',
        margin: 10,
      },
      instructions: {
        textAlign: 'center',
        color: '#333333',
        fontSize: 19,
        marginBottom: 5,
      },
    });
    
    AppRegistry.registerComponent('SampleApp', () => SampleApp);
    
    let ipsum = "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."
    

    【讨论】:

    • 无法在 iPhone 上运行示例,也无法在网站上运行。
    • 看起来 RNPlay 网站目前有问题,抱歉!很高兴它起作用了:)
    猜你喜欢
    • 2018-01-27
    • 1970-01-01
    • 2020-12-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-06-27
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多