React Native(10)小技巧

序言

最近写了几个项目,也重构了一些老项目,架构也换了,项目直接从很老的0.25 直接跨到0.54.4版本了;
在项目的重构和重新设计中也从中学到了一些东西和技巧,因为一直忙,所以没有时间写博客,所以.....今天终于抽出来时间写了,不啰嗦直接上代码,直接输出干货,不懂的老铁可以私信我;

吧啦吧啦一大堆;

1.升级到0.54.4 出现很多兼容性问题(这么解决)

公司的React Native项目 0.25.1升级 到0.54.4 版本,出现了很多兼容性问题,之前是ES5写的,索性我直接把整个项目换到了ES6,剩下的就是换新框架的API 然后梳理逻辑,(米家私有API)我就不介绍了,对你们帮助不大,毕竟你们公司不会用到这些东西,但是我还是提供了github 的链接给你们,如果你们有兴趣可以了解一下;

举个例子

var React = require('react-native');
var {
  Image,
  ListView,
  TouchableHighlight,
  StyleSheet,
  Text,
  View,
} = React;

var DemoPage = React.createClass({

  propTypes: {
    params1:React.PropTypes.object,
    params2:React.PropTypes.bool,
    params3:React.PropTypes.func,
    params4:React.PropTypes.number,
  },
  getDefaultProps() {
      return {
      params1:'Default_one',
      params2:'Default_two',
      params3:'Default_three',
      params4:'Default_four',
      };
  },
  getInitialState() {
      return {
        params1:'one',
        params2:'two',
        params3:'three',
        params4:'four',
    }
  },
  componentWillMount: function() {

  },
  componentDidMount: function(){

  },
  componentWillUnmount: function(){

  },
  attributeOne:10,
  attributeTwo:[],

  /* 这两个一般在方法里通过this调用 比如( this.attributeOne )*/
  render:function(){

    return(
    <View style={{flex:1,backgroundColor:'#ffffff'}}>
      <Text>{this.state.params1}</Text>
      <Text>{this.state.params2}</Text>
      <Text>{this.state.params3}</Text>
      <Text>{this.state.params4}</Text>
    </View>)
  },
  loadData: function(){
    /*
    获取数据等其它方法
    */
  },

});

module.exports = DemoPage;

升级RN 版本后对应的改造方法(ES6)

import React,{component} from 'react' ;
import {
  Image,
  ListView,
  TouchableHighlight,
  StyleSheet,
  Text,
  View,
} from 'react-native';

DemoPage.getDefaultProps = {
  params1:'Default_one',
  params2:'Default_two',
  params3:'Default_three',
  params4:'Default_four',
}

export default class DemoPage extends React.Component{

 static propTypes= {
    params1:React.PropTypes.object,
    params2:React.PropTypes.bool,
    params3:React.PropTypes.func,
    params4:React.PropTypes.number,
  }
  
  /*
  getInitialState 改成 constructor构造方法
  */
 constructor(props){
      super(props);
      this.state = {
        params1:'one',
        params2:'two',
        params3:'three',
        params4:'four',
      },
      this.attributeOne=10;
      this.attributeTwo=[];
  }
  componentWillMount() {

  }
  componentDidMount(){

  }
  componentWillUnmount(){

  }
  render(){

    return(
    <View style={{flex:1,backgroundColor:'#ffffff'}}>
      <Text>{this.state.params1}</Text>
      <Text>{this.state.params2}</Text>
      <Text>{this.state.params3}</Text>
      <Text>{this.state.params4}</Text>
    </View>)
  }

  loadData(){
    /*
     获取数据等其它方法
    */
  }

}

米家RN 新框架链接:

米家老框架ios-rn-sdk;

米家新框架miot-plugin-sdk;

1.Props:小技巧

class CheckLink extends React.Component{
  render(){
    // 这样会把 CheckList 所有的 props 复制到 <aElementView>
    return <ElementView {...this.props}>{'props内容拼接'}{this.props.children}</ElementView>;
  }
}

2.propTypes:校验

可以声明 prop 为指定的 JS 基本类型。默认情况下,这些 prop 都是可传可不传的

 static propTypes= {
     params1:React.PropTypes.bool,
     params2:React.PropTypes.func,
     params3:React.PropTypes.number,
     params4:React.PropTypes.object,
     params5:React.PropTypes.string,
     params6:React.PropTypes.element,
  }

所有可以被渲染的对象:数字,字符串,DOM 元素或包含这些类型的数组。

params_Node:React.PropTypes.node,

指定props 为React 元素

optionalElement: React.PropTypes.element,

用 JS 的 instanceof 操作符声明 prop 为某种类的实例

optionalMessage: React.PropTypes.instanceOf(Message),

用 enum 来限制 prop 只接受指定的值

optionalEnum: React.PropTypes.oneOf(['News', 'Photos']),

指定的多个对象类型中的一个

optionalUnion: React.PropTypes.oneOfType([
  React.PropTypes.string,
  React.PropTypes.number,
  React.PropTypes.instanceOf(Message)
]),

指定类型组成的数组

optionalArrayOf: React.PropTypes.arrayOf(React.PropTypes.number),

指定类型的属性构成的对象

optionalObjectOf: React.PropTypes.objectOf(React.PropTypes.number),

特定形状参数的对象

optionalObjectWithShape: React.PropTypes.shape({
  color: React.PropTypes.string,
  fontSize: React.PropTypes.number
}),

以后任意类型加上 isRequired 来使 prop 不可空

requiredFunc: React.PropTypes.func.isRequired,

不可空的任意类型

requiredAny: React.PropTypes.any.isRequired,

3.常用的常量定义技巧

因为开发中,基本要用到页面适配,机型适配,不可避免的 要用到屏幕宽度、屏幕高度、导航头高度、是否是iphoneX、iphone X底部安全距离等常量,所以.... 嘿嘿嘿,定义一个常量的类,然后导出即可

import React from 'react';
import {
  Platform,
  Dimensions,
} from 'react-native';

const isIPX = (Dimensions.get('window').height>=1218)?(true):(false);
const APPBAR_HEIGHT = Platform.OS === 'ios' ? 44 : 56;
const ScreenWidth = Dimensions.get('window').width;
const ScreenHeight = Dimensions.get('window').height;

var ConstDefine = {
  /* navigator 高度*/
  APPBAR_HEIGHT:  APPBAR_HEIGHT,
  /* 导航头 高度*/
  NavigatorBarHeight: (isIPX==true)?(44+64):(APPBAR_HEIGHT +20),
  /* iphone X 顶部安全区域高度 */
  APPBAR_MARGINTOP: (isIPX==true)?(44):(0),
  /* iphone X 底部安全区域高度 */
  APPBAR_MARGINBOTTOM: (isIPX==true)?(34):(0),
  /* 是否是iphone X */
  isIPX:isIPX,
  /* 屏幕宽 */
  screenWidth:ScreenWidth,
  /* 屏幕高 */
  screenHeight:ScreenHeight,
  
  ratio:ScreenWidth / 375,
}

module.exports = ConstDefine;

/* 在别的页面,引用即可,统一适配 */

import {
  APPBAR_HEIGHT,APPBAR_MARGINBOTTOM,APPBAR_MARGINTOP,isIPX ,
  ratio,NavigatorBarHeight,screenWidth,screenHeight} from '../ConstDefine';

4.react-native 常用命令

npm install xxxx —save (xxxx为库的名字)

react-native start --port 9999

1.5 React Native 打包

  1. 正常进入RN工程的根目录 在Terminal终端 输入以下命令 得到 index.ios.jsbundleassets 资源文件

  2. index.ios.jsbundleassets资源拖进工程,并确保assets 文件夹为蓝色(正确引用)才可以;

     react-native bundle --entry-file index.js --platform ios --dev false --bundle-output ./ios/bundle/index.ios.jsbundle --assets-dest ./ios/bundle 
    

1.6 React Native Navigation 导航头设置

 static navigationOptions = {
    title: 'OC和React-Native交互', // 设置头部标题
    headerStyle:{
        backgroundColor:'#F7D05E', //设置NavigationBar背景色
    },
    headerTintColor: '#fff',//设置Tint颜色
    headerTitleStyle: {
        fontWeight: 'bold',// 设置中间Title 的样式
    },
    headerTransparent: true,// 设置NavigationBar 透明
};
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,084评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,623评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,450评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,322评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,370评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,274评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,126评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,980评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,414评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,599评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,773评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,470评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,080评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,713评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,852评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,865评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,689评论 2 354

推荐阅读更多精彩内容