前言

  • 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习

  • 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所偏差,在学习中如果有错会及时修改内容,也欢迎万能的朋友们批评指出,谢谢

  • 文章第一版出自简书,如果出现图片或页面显示问题,烦请转至 简书 查看 也希望喜欢的朋友可以点赞,谢谢

React Native组件化介绍


  • React Native的核心思想就是组件化,相当于MVC的view,因此开发应用的最佳方式就是将功能组件化

  • 组件化最大的优点可以使Android和iOS能够很方便地用很少地代码使用同一套组件,增加代码的复用性

  • React Native的组件化很简单,基本步骤如下

    • 引用需要的库
    	// 引用
    import React, { Component } from 'react';
    import {
    需要用到的组件库
    } from 'react-native';
    • 实例化视图入口
    	// 实例化视图入口
    // 因为现在还是在想ES6转化过程中,为了更好的兼容性,这边使用的是ES5的格式
    var 组件名 = React.createClass({
    render(){
    return(
    需要实例化的视图
    );
    }
    });
    • 视图样式入口
    	// 视图样式入口
    // 因为现在还是在想ES6转化过程中,为了更好的兼容性,这边使用的是ES5的格式
    var styles = StyleSheet.create({
    相应视图的样式
    });
    • 注册并输出组件
    	module.exports = 组件名;
    
    
  • 生成组件后就可以在ios和android中使用生成后的组件了

    • 引入组件库
    	// 引入组件库
    var 自定义组件名 = require('./组件名');
    • 使用生成的组件
    	export default class TestRN2 extends Component {
    render() {
    return (
    <自定义组件名></自定义组件名>
    );
    }
    }
  • 到此,组件化就简单介绍到这,下面用一个综合的实例来更好地帮助理解

React Native组件化综合实例


  • 这边我们通过完成微信的登录界面这个实例来详细讲组件化的使用,先来看看微信登录界面长啥样

  • 先来创建JS文件,初始化一下格式并在index.ios.js中使用这个组件

    • 初始化JS格式
    	import React, { Component } from 'react';
    import {
    AppRegistry,
    StyleSheet,
    Text,
    View,
    Image,
    TextInput,
    TouchableOpacity
    } from 'react-native'; // 实例化入口
    var Login = React.createClass({
    render() {
    return (
    <View style={styles.container}> </View>
    );
    }
    }); // 样式
    var styles = StyleSheet.create({
    container: {
    flex:1,
    // 背景色
    backgroundColor:'white'
    },
    }); // 注册输出组件
    module.exports = Login;
    • 使用组件
    	import React, { Component } from 'react';
    import {
    AppRegistry,
    StyleSheet
    } from 'react-native'; // 引用Login组件
    var Login = require('./Login'); export default class WeiXin extends Component {
    render() {
    return (
    <View style={styles.container}>
    {/* 登录模块 */}
    <Login></Login>
    </View>
    );
    }
    }

    效果:

  • 我们把界面整体分为上下2大部分,先将这两部分搞出来

    • 视图部分
    	// 视图
    var Login = React.createClass({
    render() {
    return(
    <View style={styles.container}>
    {/* 上部登录框 */}
    <View style={styles.loginViewStyle}> </View>
    {/* 下部更多登录方式 */}
    <View style={styles.moreLoginViewStyle}> </View>
    </View>
    );
    }
    });
    • 样式部分
    	// 样式
    var styles = StyleSheet.create({ container: {
    flex:1,
    // 背景色
    backgroundColor:'white',
    // 对齐方式
    justifyContent:'space-between',
    alignItems:'center'
    }, loginViewStyle: {
    // 尺寸
    width:width * 0.9,
    height:300, // 预设,等会会清除
    // 背景色
    backgroundColor:'red',
    // 上边距
    marginTop:85
    }, moreLoginViewStyle: {
    // 尺寸
    width:width * 0.9,
    height:40, // 预设,等会会清除
    // 背景色
    backgroundColor:'red',
    // 下边距
    marginBottom:30
    }
    });

    效果:

  • 接着我们来具体完成上面登录框中的各个模块

    • 视图部分
    	// 视图
    var Login = React.createClass({
    render() {
    return(
    <View style={styles.container}>
    {/* 上部登录框 */}
    <View style={styles.loginViewStyle}>
    {/* 头像 */}
    <Image source={{uri:'icon'}} style={styles.iconStyle}></Image>
    {/* 账号 */}
    <Text style={{fontSize:17, margin:10}}>12345</Text>
    {/* 密码输入框 */}
    <View style={styles.passwordViewStyle}>
    {/* 左边图片 */}
    <Image source={{uri:'password'}} style={styles.passwordImageStyle}></Image>
    {/* 右边输入框 */}
    <TextInput style={styles.passwordInputStyle}
    placeholder='请填写密码'
    ></TextInput>
    </View>
    {/* 登录按钮 */}
    <View style={styles.loginButtonStyle}>
    <Text style={{fontSize:17, color:'white'}}>登 录</Text>
    </View>
    {/* 忘记密码选项 */}
    <Text style={{fontSize:15, color:'blue', marginTop: 15}}>登录遇到问题?</Text>
    </View>
    {/* 下部更多登录方式 */}
    <View style={styles.moreLoginViewStyle}> </View>
    </View>
    );
    }
    });
    • 样式部分
    	// 样式
    var styles = StyleSheet.create({ container: {
    flex:1,
    // 背景色
    backgroundColor:'white',
    // 对齐方式
    justifyContent:'space-between',
    alignItems:'center'
    }, loginViewStyle: {
    // 尺寸
    width:width * 0.9,
    // 背景色
    backgroundColor:'red',
    // 上边距
    marginTop:85,
    // 对齐方式
    alignItems:'center'
    }, iconStyle: {
    // 尺寸
    width:iconWH,
    height:iconWH
    }, passwordViewStyle: {
    // 尺寸
    width:width * 0.9,
    height:passwordViewH,
    // 背景色
    backgroundColor:'yellow',
    // 上边距
    marginTop:20,
    // 主轴方向
    flexDirection:'row',
    // 对齐方式
    alignItems:'center',
    // 下边框
    borderBottomWidth:1,
    borderBottomColor:'green'
    }, passwordImageStyle: {
    // 尺寸
    width:passwordImageWH,
    height:passwordImageWH,
    // 图片填充方式
    resizeMode:'contain',
    // 左边距
    marginLeft:passwordMargin
    }, passwordInputStyle: {
    // 尺寸
    width:width * 0.9 - (passwordMargin * 3 + passwordImageWH),
    height:passwordViewH,
    // 背景色
    backgroundColor:'white',
    // 左边距
    marginLeft:passwordMargin
    }, loginButtonStyle: {
    // 尺寸
    width:width * 0.9,
    height:44,
    // 背景色
    backgroundColor:'green',
    // 上边距
    marginTop:20,
    // 居中对齐
    justifyContent:'center',
    alignItems:'center'
    }, moreLoginViewStyle: {
    // 尺寸
    width:width * 0.9,
    height:40,
    // 背景色
    backgroundColor:'red',
    // 下边距
    marginBottom:30
    }
    });

    效果:

  • 现在我们把测试用的背景色去掉看看效果,是不是很接近微信的界面了

    效果:

  • 接下来我们来完成下半部分

    • 视图部分
    	{/* 下部更多登录方式 */}
    <View style={styles.moreLoginViewStyle}>
    <Text style={{color:'blue', fontSize:17}}>更多</Text>
    </View>
    • 样式部分
    	moreLoginViewStyle: {
    // 尺寸
    width:width * 0.9,
    height:40,
    // 背景色
    backgroundColor:'red',
    // 下边距
    marginBottom:30,
    // 对齐方式
    alignItems:'center',
    justifyContent:'center'
    }

    效果:

  • 去掉测试时候的背景色,界面就搭建完毕了,效果如下

    效果:

  • 接下来就是让图片、按钮、忘记密码、更多这几个标签拥有接受触摸事件并做出反应的能力,这边就以更多为例

    • 包装示例
    	<TouchableOpacity
    activeOpacity={0.5}
    onPress={() => {alert('点击了更多')}}
    >
    {/* 下部更多登录方式 */}
    <View style={styles.moreLoginViewStyle}>
    <Text style={{color:'blue', fontSize:17}}>更多</Text>
    </View>
    </TouchableOpacity>

    效果:

  • 最后将组件完整的代码和效果图贴出来,供参考

    	import React, { Component } from 'react';
    import {
    AppRegistry,
    StyleSheet,
    Text,
    View,
    TextInput,
    Image,
    TouchableOpacity
    } from 'react-native'; var Dimensions = require('Dimensions');
    var {width, height} = Dimensions.get('window'); // 常用参数
    var iconWH = 70;
    var passwordViewH = 30;
    var passwordImageWH = 25;
    var passwordMargin = 5; // 视图
    var Login = React.createClass({
    render() {
    return(
    <View style={styles.container}>
    {/* 上部登录框 */}
    <View style={styles.loginViewStyle}>
    <TouchableOpacity
    activeOpacity={0.5}
    onPress={() => {alert('点击了头像')}}
    >
    {/* 头像 */}
    <Image source={{uri:'icon'}} style={styles.iconStyle}></Image>
    </TouchableOpacity>
    {/* 账号 */}
    <Text style={{fontSize:17, margin:10}}>12345</Text>
    {/* 密码输入框 */}
    <View style={styles.passwordViewStyle}>
    {/* 左边图片 */}
    <Image source={{uri:'password'}} style={styles.passwordImageStyle}></Image>
    {/* 右边输入框 */}
    <TextInput style={styles.passwordInputStyle}
    placeholder='请填写密码'
    ></TextInput>
    </View>
    <TouchableOpacity
    activeOpacity={0.5}
    onPress={() => {alert('点击了登录按钮')}}
    >
    {/* 登录按钮 */}
    <View style={styles.loginButtonStyle}>
    <Text style={{fontSize:17, color:'white'}}>登 录</Text>
    </View>
    </TouchableOpacity>
    <TouchableOpacity
    activeOpacity={0.5}
    onPress={() => {alert('点击了忘记密码选项')}}
    >
    {/* 忘记密码选项 */}
    <Text style={{fontSize:15, color:'blue', marginTop: 15}}>登录遇到问题?</Text>
    </TouchableOpacity>
    </View>
    <TouchableOpacity
    activeOpacity={0.5}
    onPress={() => {alert('点击了更多')}}
    >
    {/* 下部更多登录方式 */}
    <View style={styles.moreLoginViewStyle}>
    <Text style={{color:'blue', fontSize:17}}>更多</Text>
    </View>
    </TouchableOpacity>
    </View>
    );
    }
    }); // 样式
    var styles = StyleSheet.create({ container: {
    flex:1,
    // 背景色
    backgroundColor:'white',
    // 对齐方式
    justifyContent:'space-between',
    alignItems:'center'
    }, loginViewStyle: {
    // 尺寸
    width:width * 0.9,
    // 上边距
    marginTop:85,
    // 对齐方式
    alignItems:'center'
    }, iconStyle: {
    // 尺寸
    width:iconWH,
    height:iconWH
    }, passwordViewStyle: {
    // 尺寸
    width:width * 0.9,
    height:passwordViewH,
    // 上边距
    marginTop:20,
    // 主轴方向
    flexDirection:'row',
    // 对齐方式
    alignItems:'center',
    // 下边框
    borderBottomWidth:1,
    borderBottomColor:'green'
    }, passwordImageStyle: {
    // 尺寸
    width:passwordImageWH,
    height:passwordImageWH,
    // 图片填充方式
    resizeMode:'contain',
    // 左边距
    marginLeft:passwordMargin
    }, passwordInputStyle: {
    // 尺寸
    width:width * 0.9 - (passwordMargin * 3 + passwordImageWH),
    height:passwordViewH,
    // 左边距
    marginLeft:passwordMargin
    }, loginButtonStyle: {
    // 尺寸
    width:width * 0.9,
    height:44,
    // 背景色
    backgroundColor:'green',
    // 上边距
    marginTop:20,
    // 居中对齐
    justifyContent:'center',
    alignItems:'center'
    }, moreLoginViewStyle: {
    // 尺寸
    width:width * 0.9,
    height:40,
    // 下边距
    marginBottom:30,
    // 对齐方式
    alignItems:'center',
    justifyContent:'center'
    }
    }); module.exports = Login;

效果:

React Native 之 组件化开发的更多相关文章

  1. 采用React+Ant Design组件化开发前端界面(一)

    react-start 基础知识 1.使用脚手架创建项目并启动 ​ 1.1 安装脚手架: npm install -g create-react-app ​ 1.2 使用脚手架创建项目: create ...

  2. 从DOM操作看Vue&React的前端组件化,顺带补齐React的demo

    前言 接上文:谈谈我对前端组件化中“组件”的理解,顺带写个Vue与React的demo 上次写完博客后,有朋友反应第一内容有点深,看着迷迷糊糊:第二是感觉没什么使用场景,太过业务化,还不如直接写Vue ...

  3. ReactNative新手学习之路04 组件化开发轮播图swiper支持安卓和IOS

    react native 新手之路04 组件化开发轮播图swiper支持安卓和IOS npm install react-native-carousel --save git 地址Properties ...

  4. vue组件化开发实践

    前言 公司目前制作一个H5活动,特别是有一定统一结构的活动,都要码一个重复的轮子.后来接到一个基于模板的活动设计系统的需求,便有了一下的内容.首先会对使用Vue进行开发的一些前期需要的技术储备进行简单 ...

  5. vue.js组件化开发实践

    前言 公司目前制作一个H5活动,特别是有一定统一结构的活动,都要码一个重复的轮子.后来接到一个基于模板的活动设计系统的需求,便有了下面的内容.借油开车. 组件化 需求一到,接就是怎么实现,技术选型自然 ...

  6. 基于React Native的58 APP开发实践

    React Native在iOS界早就炒的火热了,随着2015年底Android端推出后,一套代码能运行于双平台上,真正拥有了Hybrid框架的所有优势.再加上Native的优秀性能,让越来越多的公司 ...

  7. 前端笔记之JavaScript面向对象(四)组件化开发&轮播图|俄罗斯方块实战

    一.组件化开发 1.1组件化概述 页面特效的制作,特别需要HTML.CSS有固定的布局,所以说现在越来越流行组件开发的模式,就是用JS写一个类,当你实例化这个类的时候,页面上的效果布局也能自动完成. ...

  8. React Native Android原生模块开发实战|教程|心得|怎样创建React Native Android原生模块

    尊重版权,未经授权不得转载 本文出自:贾鹏辉的技术博客(http://blog.csdn.net/fengyuzhengfan/article/details/54691503) 告诉大家一个好消息. ...

  9. Vue 入门之组件化开发

    Vue 入门之组件化开发 组件其实就是一个拥有样式.动画.js 逻辑.HTML 结构的综合块.前端组件化确实让大的前端团队更高效的开发前端项目.而作为前端比较流行的框架之一,Vue 的组件和也做的非常 ...

随机推荐

  1. mono中发送邮件并保存本次收件人的地址

    在ios端mono开发中,发送邮件可以选择调用ios原生email程序.有两种方式实现这种功能,一是程序跳转到ipad中email程序,另外一种是将发送邮件的界面在自己应用里弹出. 首先第一种方式的代 ...

  2. Git 进阶指南(git ssh keys / reset / rebase / alias / tag / submodule )

    在掌握了基础的 Git 使用 之后,可能会遇到一些常见的问题.以下是猫哥筛选总结的部分常见问题,分享给各位朋友,掌握了这些问题的中的要点之后,git 进阶也就完成了,它包含以下部分: 如何修改 ori ...

  3. WinForm中显示PDF文件

    一.VS2013中,菜单-工具-选择工具箱项-COM组件-勾选“Adobe PDF Reader”-确定 二.在工具箱中就可以看到Adobe PDF Reader控件了,拖到窗体上. 拖到窗体上之后, ...

  4. PHP 调用webService方式

    方法如下: <?php header('Content-Type: text/html; charset=UTF-8'); define('APP_ROOT', dirname(__FILE__ ...

  5. MySQL触发器-条件触发器语法

    文章为作者原创,未经许可,禁止转载.    -Sun Yat-sen University 冯兴伟 实验4 触发器 )实验目的 掌握数据库触发器的设计和使用方法 )实验内容和要求 定义BEFORE触发 ...

  6. Android Studio vs. Eclipse ADT Comparison

    Android Studio 是一个新的基于 IntelliJ IDEA Android 的安卓开发环境,它对 Eclipse ADT 进行了改进并新增了功能. Feature Android Stu ...

  7. Java资源大全中文版(Awesome最新版)

    Awesome系列的Java资源整理.awesome-java 就是akullpp发起维护的Java资源列表,内容包括:构建工具.数据库.框架.模板.安全.代码分析.日志.第三方库.书籍.Java 站 ...

  8. 计算机程序的思维逻辑 (46) - 剖析PriorityQueue

    上节介绍了堆的基本概念和算法,本节我们来探讨堆在Java中的具体实现类 - PriorityQueue. 我们先从基本概念谈起,然后介绍其用法,接着分析实现代码,最后总结分析其特点. 基本概念 顾名思 ...

  9. 如何通过官方渠道为Windows 10 添加具有中国特色的字体

    Windows 10的变化细节上个人认为要比Windows 8多很多,而且很多功能找到之后还是小惊喜,就是挺多好用的地方居然都不正经宣传一下,微软真是搞得悄悄地干活? 今天为大家介绍一下通过官方途径添 ...

  10. iOS引入JavaScriptCore引擎框架(一)

    JavaScriptCore引擎     我们都知道WebKit是个渲染引擎,简单来说负责页面的布局,绘制以及层的合成,但是WebKit工程中不仅仅有关于渲染相关的逻辑,也集成了默认的javascri ...