zoukankan      html  css  js  c++  java
  • 【水滴石穿】MyFirstRNDemo

    比较简单的项目

    //index.js
    /** @format */
    
    import {AppRegistry} from 'react-native';
    //默认创建的类
    import App from './App';
    //json
    import {name as appName} from './app.json';
    //FlatList类
    import DWBFlatList from './DWBHomeFlatList'
    
    import DWBTestVC from './DWBTestVC'
    
    import DWBTButton from './DWBTButton'
    
    
    
    // import DWBSwipeout from './DWBSwipeout'
    
    import DWBNavVC from './DWBNavVC'
    import DWBTouchableOpacity from './DWBTouchableOpacity'
    
    import DWBSectionList from './DWBSectionList'
    
    import DWBActionButton from './DWBActionButton'
    
    
    
    //修改这里可以切换不同的类显示: => App
    AppRegistry.registerComponent(appName, () => DWBFlatList);
    
    // react-native关闭所有黄色警告,将这两句话加在index.js文件中,放在AppRegistry.registerComponent('App', () => App)之前。
    console.ignoredYellowBox = ['Warning: BackAndroid is deprecated. Please use BackHandler instead.','source.uri should not be an empty string','Invalid props.style key'];
    
    console.disableYellowBox = true // 关闭全部黄色警告
    
    

    //DWBHomeFlatList.js
    import React, { Component } from 'react';
    import {
        AppRegistry,
        StyleSheet,
        Text,
        View,
        FlatList,
        TouchableOpacity, Button,
    } from 'react-native';
    
    // 初始化数据
    var Arr = [
        {name:'河北省',},
        {name:'山西省',},
        {name:'辽宁省',},
        {name:'吉林省',},
        {name:'黑龙江省',},
        {name:'江苏省',},
        {name:'浙江省',},
        {name:'福州省',}];
    
    export default class MyFlatList extends Component {
    
        render() {
            //给数据追加一个key的字段,不然会有警告的,参数数组中的每一项,需要包含 key 值作为唯一标示
            for (var i = 0; i < Arr.length; i++) {
                Arr[i]['key'] = i;
            }
            return (
                //初始化FlatList
                <View style={styles.container}>
                    <FlatList style={styles.FlatListStyle}
                              data = {Arr}
                              ListHeaderComponent={this.ListHeaderComponent.bind(this)}
                              ListFooterComponent={this.ListFooterComponent.bind(this)}
                              renderItem={this.renderItemView.bind(this)}
                              //分割线组件
                              ItemSeparatorComponent={ItemDivideComponent}
                    >
    
                    </FlatList>
    
    
    
                </View>
            );
        }
    
        //列表的每一行
        renderItemView({item,index}){
            return(
    
                <TouchableOpacity onPress={()=>{
                    this.Cellheader(item)}
                }
                >
                    <View style={{
                        backgroundColor:'#ffffff',//背景色
                        height:59,//view高度
                        justifyContent:'center',//内容上下居中
                        alignItems: 'center'//内容左右居中
                    }}>
    
                        <Text>{item.name}</Text>
    
    
                    </View>
    
                </TouchableOpacity>
            );
        }
    
        //点击每一行的对象
        Cellheader(data){
            alert(data.name);
        }
    
        //定义页头
        ListHeaderComponent(){
            return(
                <View style={{height:140,backgroundColor:'red',justifyContent: 'center',}}>
                    <Text>我是页头</Text>
                </View>
            );
        }
        //定义页脚
        ListFooterComponent(){
            return(
                <View style={{height:140,backgroundColor:'yellow',justifyContent: 'center',}}>
                    <Text>我是页脚</Text>
                </View>
            );
        }
    }
    
    // //设置分割线
    // renderSeparator(){
    //     return (
    //         <View style={{height: 1, backgroundColor: 'skyblue'}}></View>
    //     );
    // };
    
    
    class ItemDivideComponent extends Component {
        render() {
            return (
                <View style={{height: 1, backgroundColor: 'skyblue'}}></View>
            );
        }
    };
    
    const styles = StyleSheet.create({
        //控制器属性
        container: {
            flex: 1,
            flexDirection: 'column',
            justifyContent: 'space-between',
            backgroundColor: '#F5FCFF',
        },
    //FlatList属性
        FlatListStyle:{
            backgroundColor:'#f6f6f6',
            flex:1,
            marginTop:64,
            marginBottom: 100,
            // 300
        }
    
    });
    
    
    
    //DWBActionButton.js
    import React, { Component } from 'react';
    import { StyleSheet, View,Text,Alert } from 'react-native';
    import ButtonMy from 'apsl-react-native-button'
    
    
    export default class ActionButton extends Component {
    
            render() {
            return (
    
                <View style={styles.ViewSyt}>
                    <ButtonMy style={{backgroundColor: '#c771ec'}} onPress={()=>{
                        Alert.alert('我是一个button');
                    }}>
                        <View style={styles.actionButtonIcon}>
                            <Text style={styles.actionButtonIcon}>我是一个button</Text>
                        </View>
                    </ButtonMy>
                </View>
    
    
            );
        }
    
    }
    
    const styles = StyleSheet.create({
        ViewSyt:{
            flex:1,
            marginTop:100,
            fontSize: 20,
            height: 40,
            color: 'white',
    
        },
    
        actionButtonIcon: {
            fontSize: 20,
            height: 22,
            color: 'white',
        },
    });
    

    比较基础,=-=

  • 相关阅读:
    Java 中几种常用的线程池
    阿里巴巴java工程师面试经验详情
    设计模式-备忘录模式
    设计模式-职责链模式
    设计模式-中介者模式
    设计模式-解释器模式
    设计模式-观察者模式
    设计模式-迭代器模式
    设计模式-命令模式
    设计模式-模板方法模式
  • 原文地址:https://www.cnblogs.com/smart-girl/p/10899590.html
Copyright © 2011-2022 走看看