React Native之ViewPagerAndroid 元件
阿新 • • 發佈:2019-02-18
ViewPagerAndroid例項
為了更好的理解,我們自己實現一個例項,效果如下:import React, { Component } from 'react'; import { AppRegistry, StyleSheet, Text, ViewPagerAndroid, TouchableOpacity, Image, View } from 'react-native'; var PAGES = 2; var IMAGE_URIS = [ 'http://apod.nasa.gov/apod/image/1410/20141008tleBaldridge001h990.jpg', 'http://apod.nasa.gov/apod/image/1409/volcanicpillar_vetter_960.jpg', ]; export default class ViewPagerDemo extends Component { state={ page:0, }; render() { var pages = []; for(let i = 0;i < PAGES;i++){ pages.push( <View key={i} collapsable={false}> <TouchableOpacity activeOpacity={1} onPress={this.onPress} > <Image style={styles.image} source={{uri:IMAGE_URIS[i]}}> </Image> </TouchableOpacity> </View> ); } return ( <View style={styles.container}> <ViewPagerAndroid style={styles.viewPager} initialPage={0} onPageSelected={this.onPageSelected} > {pages} </ViewPagerAndroid> <Text style={{flex:1,alignSelf:'center'}}>當前第{this.state.page+1}頁</Text> </View> ); } onPageSelected=(e)=>{ this.setState({page:e.nativeEvent.position}); } onPress=()=>{ alert('第'+(this.state.page+1)+'頁被點選了'); } } const styles = StyleSheet.create({ container: { flex: 1, backgroundColor: '#F5FCFF', }, image: { height: 200, padding: 20, }, viewPager: { flex: 1, }, }); AppRegistry.registerComponent('ViewPagerDemo', () => ViewPagerDemo);