zoukankan      html  css  js  c++  java
  • react-native构建基本页面2---轮播图+九宫格

    配置首页的轮播图

    1. 轮播图官网
    2. 运行npm i react-native-swiper --save安装轮播图组件
    3. 导入轮播图组件import Swiper from 'react-native-swiper';
    4. 其中,在Swiper身上,showsPagination={false}是用来控制页码的;showsButtons={false}是用来控制左右箭头显示与隐藏;height={160}是用来控制轮播图区域的高度的!
    5. 设置轮播图的样式:
    var styles = StyleSheet.create({
        wrapper: {},
        slide1: {
            flex: 1,
            justifyContent: 'center',
            alignItems: 'center',
            backgroundColor: '#9DD6EB',
        },
        slide2: {
            flex: 1,
            justifyContent: 'center',
            alignItems: 'center',
            backgroundColor: '#97CAE5',
        },
        slide3: {
            flex: 1,
            justifyContent: 'center',
            alignItems: 'center',
            backgroundColor: '#92BBD9',
        },
        image:{
            '100%',
            height:'100%'
        }
    })
    
    1. 将组件的代码结构引入到页面上:
    <Swiper style={styles.wrapper} showsButtons={true} height={160} autoplay={true}>
                    <View style={styles.slide1}>
                        <Image source={{uri:'http://www.itcast.cn/images/slidead/BEIJING/2017410109413000.jpg'}} style={styles.image}></Image>
                    </View>
                    <View style={styles.slide2}>
                        <Image source={{uri:'http://www.itcast.cn/images/slidead/BEIJING/2017440109442800.jpg'}} style={styles.image}></Image>
                    </View>
                    <View style={styles.slide3}>
                        <Image source={{uri:'http://www.itcast.cn/images/slidead/BEIJING/2017441409442800.jpg'}} style={styles.image}></Image>
                    </View>
                </Swiper>
    
    import React, { Component } from 'react'
    import { View, Text, StyleSheet, Image, TouchableHighlight } from 'react-native'
    
    // 导入轮播图组件
    import Swiper from 'react-native-swiper'
    // 轮播图样式
    var styles = StyleSheet.create({
      box: {
         '33.33%',
        alignItems: 'center',
        marginTop: 15
      }
    })
    
    // Actions 表示要进行路由的JS操作了,可以跳转到新路由
    import { Actions } from 'react-native-router-flux'
    
    export default class Home extends Component {
      constructor(props) {
        super(props)
        this.state = {
          lunbotu: [] // 轮播图数组
        }
      }
    
    
      componentWillMount() {
        fetch('http://vue.studyit.io/api/getlunbo')
          .then(res => res.json())
          .then(data => {
            // console.warn(JSON.stringify(data, null, '  '))
            this.setState({
              lunbotu: data.message
            })
          })
      }
    
      render() {
        return <View>
    
          {/* 轮播图的结构 */}
          {/* 在 轮播图的 Swiper 组件外面,需要套一层 View,给这个 View 需要手动设置一个高度 */}
          <View style={{ height: 220 }}>
            <Swiper style={styles.wrapper} showsButtons={true} autoplay={true} loop={true}>
    
              {this.state.lunbotu.map((item, i) => {
                return <View key={i}>
                  <Image source={{ uri: item.img }} style={{  '100%', height: '100%' }}></Image>
                </View>
              })}
    
            </Swiper>
          </View>
    
          {/* 在 RN 中,默认,就已经为 所有的 View 启用了弹性和模型,同时,默认的主轴是 纵向的 */}
          <View style={{ flexDirection: 'row', flexWrap: 'wrap' }}>
    
            <View style={styles.box}>
              <Image source={require('../../images/menu1.png')} style={{  60, height: 60 }}></Image>
              <Text>新闻资讯</Text>
            </View>
    
            <View style={styles.box}>
              <Image source={require('../../images/menu2.png')} style={{  60, height: 60 }}></Image>
              <Text>图片分析</Text>
            </View>
    
            <View style={styles.box}>
              <Image source={require('../../images/menu3.png')} style={{  60, height: 60 }}></Image>
              <Text>商品购买</Text>
            </View>
    
            <View style={styles.box}>
              <Image source={require('../../images/menu4.png')} style={{  60, height: 60 }}></Image>
              <Text>视频专区</Text>
            </View>
    
            <TouchableHighlight onPress={this.goMovieList} underlayColor="white" style={styles.box}>
              {/* 在 TouchableHighlight 内部,只能放置唯一的一个元素 */}
              <View>
                <Image source={require('../../images/menu5.png')} style={{  60, height: 60 }}></Image>
                <Text>热映电影</Text>
              </View>
            </TouchableHighlight>
    
            <View style={styles.box}>
              <Image source={require('../../images/menu6.png')} style={{  60, height: 60 }}></Image>
              <Text>联系我们</Text>
            </View>
    
          </View>
        </View>
      }
    
      // 去电影列表页面
      goMovieList = () => {
        // 在这里要跳转到电影列表,需要使用 编程式导航
        // this.props.history.push
        Actions.movielist()
      }
    }
    
    
    
  • 相关阅读:
    好用的开源库(一)——MaterialEditText
    Android开发——Notification通知的各种Style详解
    Android开发——Notification通知的使用及NotificationCopat.Builder常用设置API
    【转】Android开发笔记(序)写在前面的目录
    【转】NotificationCopat.Builder全部设置
    Git的简单的基本使用
    Android开发——BroadcastReceiver广播的使用
    【转】Android 开发规范(完结版)
    Android开发——使用intent传递对象
    【升级至sql 2012】sqlserver mdf向上兼容附加数据库(无法打开数据库 'xxxxx' 版本 611。请将该数据库升级为最新版本。)
  • 原文地址:https://www.cnblogs.com/ygjzs/p/12213095.html
Copyright © 2011-2022 走看看