Skip to content

Latest commit

 

History

History
287 lines (244 loc) · 10 KB

readme.md

File metadata and controls

287 lines (244 loc) · 10 KB

RN 项目相关规范

  • 开发工具(统一采用WebStorm)安装成功后,安装相关插件

    • ReactNativeTools
    • ReactNative console 该插件提供RN相关的快捷功能(启动本地服务器,打包jsbundle到Android/IOS包)
  • 第一期RN相关开发目标(钱包) 承担钱包项目,弱交互页面(展示性页面),后期随着RN相关开发的积累,再进一步拓展其应用范围。

  • js业务代码 目录结构

    • components 视图组件

    • constants 常量相关

      • colors 视图色值
      • Urls 路由名称
      • 后续根据具体需要扩展
    • page 具体页面

    • res 资源目录

      • img 图片资源
      • 其他,后续根据具体需要扩展
    • utls 工具类

      • JSonUtil Json序列化反序列化工具类
      • NetUtil 访问后端接口工具类
      • ScreenUtils 屏幕信息工具类
      • 其他,后续根据具体需要扩展
    • App.js统一入口文件,说明:在index.android.js和index.ios.js文件中,统一入口文件为App.js,且保持所在目录和index.android.js和index.ios.js同级

  • WebStorm 添加RN模板代码

    • 打开Preferences
    • Editor->File and Code Template
    • 添加ReactNative模板代码
    
    import React, {Component} from 'react'
    import {
        StyleSheet,
        View,
        Text,
        Image,
    } from 'react-native'
    
    class ${NAME} extends Component {
        render() {
            return (
                <View style={styles.container}>
    
                </View>
            );
        }
    }
    
    const styles = StyleSheet.create({
        container: {
            flex: 1,
            justifyContent: 'center',
            alignItems: 'center',
            backgroundColor: '#F5FCFF',
        }
    });
    
    export default ${NAME}
    
    
    • 新建RN .js 代码,选择ReactNative 生产模板代码
  • 页面编写规范

        constructor() {
                super()
                this.state = {
                    data: {}
                }
            }
    
    • 代码中使用props时,需进行defaultProps默认值初始化
        static defaultProps = {
                 color: '#1e90ff',
                 dotRadius: 10,
                 size: 40
             };
    
    • 代码中创建数组或对象使用以下方式
    const user={
            name:'time',
            sex:'男',
            age:25,
        };
    
    const itemArray=['0','1','2',3,{name:'25',age:'男'}];
    
    • 代码中函数绑定this,强制使用箭头函数; 注:除组件原有方法,其他自定义函数命名时,需使用箭头函数
        //系统组件生命周期方法
        constructor(props){
            super(props);
        };
        //自定义方法
        goMainPage=()=>{
            
        };
    
    • 代码中一些网络数据初始化,配置信息,推荐在此生命周期进行初始化
      componentWillMount
    • 代码中使用定时器或者DeviceEventEmitter,必须在组件卸载进行销毁或者清除
        componentDidMount() {
            //注意addListener的key和emit的key保持一致
            this.msgListener = DeviceEventEmitter.addListener('Msg',(listenerMsg) => {
                this.setState({
                    listenerMsg:listenerMsg,
                })
            });
        }
        
        goMainPage=()=>{
            this.timer = setTimeout(
                () => { console.log('把一个定时器的引用挂在this上'); },
                500
            );
        };
        
        
        componentWillUnmount() {
            //此生命周期内,去掉监听和定时器
            this.msgListener&&this.msgListener.remove();
            // 如果存在this.timer,则使用clearTimeout清空。
            // 如果你使用多个timer,那么用多个变量,或者用个数组来保存引用,然后逐个clear
            this.timer && clearTimeout(this.timer);
        }
    
    
    • 当组件使用样式属性达到三个或者三个以上时,必须使用StyleSheet来创建样式属性并进行引用
        const styles = StyleSheet.create({
             container: {
                 flex: 1,
                 justifyContent: 'center',
                 alignItems: 'center',
                 backgroundColor: '#F5FCFF',
                 marginTop:10,
             },
         });
    • 当使用单一属性,或者全局样式属性时,推荐使用公共样式类
        export default {
            white: '#ffffff',
            one_color: '#D93638',
            orange: '#FF7900',
            page_background: '#efefef',
            black: '#333333',
            black_light: '#666666',
            divider:'#cccccc'
        }
    • 当使用多个state或者props值时,推荐使用以下方式
        const {size, dotRadius, color} = this.props;
        const { maxNumber,minNumber,}=this.state;
    • var,let,const

      • 对所有变量,对象的引用,使用const,不要使用var
      • 如果一定需要引用可变动的变量,对象,建议使用let代替var
    • render()函数代码过长时,请适当进行拆分,拆分为‘‘页面内组件‘‘,提高可读性。render()函数代码行请勿超过八十行,超过之后,请自行进行拆分

    • 些输入框的值,放入到state中,并且设置defaultValue,不要使用全局变量进行引用,参照以下方式:

    constructor(props) {
        super(props);
        this.state = {
            editSalesPrice:'',  //修改后的商品售价
            editPurchasePrice:'', //修改后的商品进价
        };
    }
    
    render(){
      return(
      <View style={styles.viewPadding}>
                           <TextInput
                                style={styles.rowInput}
                                placeholder="请输入调整后的价格"
                                onChangeText={(text)=>{
                                    this.setState({
                                        editSalesPrice:text,
                                    })
                                }}
                                defaultValue={this.state.editSalesPrice}
                                placeholderTextColor='#B0B7C2'
                                underlineColorAndroid = 'transparent'
                                autoCapitalize={'none'}
                                autoCorrect={false}
                                clearButtonMode={'while-editing'}
                                keyboardType='numeric'
                            />
                        </View>
                        );
    }
    
    • 如何获取ref属性
    componentDidMount() {
            this._input.focus()
          },
    render() {
        return <TextInput ref={(c) => this._input = c} />
      },
      
    
    • React Native setNativeProps使用 有时候我们需要直接改动组件并触发局部的刷新,但不使用state或是props。 setNativeProps 方法可以理解为web的直接修改dom。使用该方法修改 View 、 Text 等 RN自带的组件 ,则不会触发组件的 componentWillReceiveProps 、 shouldComponentUpdate 、componentWillUpdate 等组件生命周期中的方法。
    class MyButton extends React.Component({
    	setNativeProps(nativeProps) {
    	     this._root.setNativeProps({   //这里输入你要修改的组件style
    	     	height:48,
    	     	backgroundColor:'red'
    	     })
    	},
    	render() {
    	     return (
    	     	<View ref={component => this._root = component} {...this.props} style={styles.button}>
    	 	        <Text>{this.props.label}</Text>
    	 	    </View>
    	     )
    	},
      })
    
    • React Native 读取本地的json文件
        import langsData from '../res/data/langs.json'
    
  • 三方开源库(https://js.coach/react-native),官网(中文 http://reactnative.cn/ 英文 http://facebook.github.io/react-native/)多参考别人是怎么写代码的

  • RN页面与原生页面通信模块

    • 原生页面跳转RN页面参数传递:
      • Android: 通过mReactRootView.startReactApplication()进行传递
      • IOS:通过 [[RCTRootView alloc] initWithBundleURL 进行传递
      • 要求其格式{params:{page:"xxxxx",key1:"xxxx",key2:"xxxx",...},page参数必须传递,其他根据RN页面具体需求进行传递
      • RN页面通过this.props.params进行接收
    • RN页面要原生提供的功能,模块名称两端(Android和IOS)统一命名为:commModule
      • 使用示例:NativeModules.commModule.xxxxx()
      • 目前原生支持的功能有:
        • 提示性信息展示:NativeModules.commModule.toast()
        • 关闭原生RN容器页面:NativeModules.commModule.closeRNPage()
        • 获取请求接口,通用参数:NativeModules.commModule.netCommParas()
        • 其他,后续根据具体需要扩展
    • RN与原生的通信
  • 调试两种方式

  • 重新加载RN页面

    • Android模拟器 cmd+M
    • IOS 模拟器

备注:相关内容来自网络整理,欢迎指正,欢迎补充