React Native 每日一学(Learn a little every day)

来源:互联网 发布:金百福软件基本视频 编辑:程序博客网 时间:2024/06/05 13:33

本文出自《React Native学习笔记》系列文章。 每天一个知识点(技巧,经验,填坑日记等),每天学一点,离大神近一点。

汇聚知识,分享精华。

如果你是一名React Native爱好者,或者有一颗热爱钻研新技术的心,喜欢分享技术干货、项目经验、以及你在React Naive学习研究或实践中的一些经验心得等等,欢迎投稿《React Native 每日一学》栏目。 
如果你是一名Android、iOS、或前端开发人员,有者一颗积极进取的心,欢迎关注《React Native 每日一学》。本栏目汇聚React Native开发的技巧,知识点,经验等。

列表

  1. D1:React Native 读取本地的json文件 (2016-8-18)
  2. D2:React Native import 文件的小技巧 (2016-8-19)
  3. D3:React Native 真机调试 (2016-8-22)
  4. D4:React Native 函数的绑定 (2016-8-23)
  5. D5:React Native setNativeProps使用 (2016-8-24)
  6. D6:ref属性不只是string(2016-8-25)
模板:   D1:标题 (日期)------概述### 子标题内容  ### 子标题内容   另外:记得在列表中添加链接

D6:ref属性不只是string(2016-8-25)

ref属性不仅接受string类型的参数,而且它还接受一个function作为callback。这一特性让开发者对ref的使用更加灵活。

 render: function() {    return (      <TextInput        ref={function(input) {          if (input != null) {            input.focus();          }        }} />    );  },

在ES6中我们可以使用箭头函数来为组件的ref设置一个callback。

  render() {    return <TextInput ref={(c) => this._input = c} />;  },  componentDidMount() {    this._input.focus();  },

需要提醒大家的是,只有在组件的render方法被调用时,ref才会被调用,组件才会返回ref。如果你在调用this.refs.xx时render方法还没被调用,那么你得到的是undefined。

心得:ref属性在开发中使用频率很高,使用它你可以获取到任何你想要获取的组件的对象,有个这个对象你就可以灵活地做很多事情,比如:读写对象的变量,甚至调用对象的函数。

D5:React Native setNativeProps使用(2016-8-24)

有时候我们需要直接改动组件并触发局部的刷新,但不使用state或是props。 setNativeProps 方法可以理解为web的直接修改dom。使用该方法修改 View 、 Text 等 RN自带的组件 ,则不会触发组件的 componentWillReceiveProps 、 shouldComponentUpdate 、componentWillUpdate 等组件生命周期中的方法。

使用例子

javascript 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> ) }, });

避免和render方法的冲突

如果要更新一个由render方法来维护的属性,则可能会碰到一些出人意料的bug。因为每一次组件重新渲染都可能引起属性变化,这样一来,之前通过setNativeProps所设定的值就被完全忽略和覆盖掉了。

D4:React Native 函数的绑定 (2016-8-23)

在ES6的class中函数不再被自动绑定,你需要手动去绑定它们。

第一种在构造函数里绑定。

  constructor(props) {super(props);// Set up initial statethis.state = {  text: props.initialValue || 'placeholder'};    // Functions must be bound manually with ES6 classesthis.handleChange = this.handleChange.bind(this); 另一种方式就是在你使用的地方通过内联来绑定:// Use `.bind`: render() {return (  <input onChange={this.handleChange.bind(this)}    value={this.state.text} />);}// Use an arrow function:render() { return (<input onChange={() => this.handleChange()}  value={this.state.text} />); 以上任意一种都可以,然而在效率上却不行了。每一次调用render(可以说是非常频繁!)一个新的函数都会被创建。与在构造函数里只绑定一次相比就慢一些。

最终的选择是使用箭头函数直接替换函数在类中的声明,像这样:

// the normal way// requires binding elsewherehandleChange(event) {  this.setState({text: event.target.value});}// the ES7 way// all done, no binding requiredhandleChange = (event) => {  this.setState({text: event.target.value  });} 通过这种方式,你不需要绑定任何东西。这都已经通过神奇的箭头函数被搞定了。像期望的那样,函数内部的this将会指向组件实例。 参考:[http://www.jianshu.com/p/a4c23654932e](http://www.jianshu.com/p/a4c23654932e)

D3:React Native 真机调试 (2016-8-22)

开发中真机调试是必不可少的,有些功能和问题模拟器是无法重现的,所以就需要配合真机测试,接下来就说下安卓和iOS的真机调试,不难,但是有很多细节需要注意

###iOS 真机调试

  1. 必须 保证调试用电脑的和你的设备处于相同的 WiFi网络环境中下
  2. 打开Xcode,找到 AppDelegate.m 文件
  3. 更改 jsCodeLocation 中的 localhost 改成你电脑的局域网IP地址
  4. IP地址点击左面右上角WIFi图标,找到打开网络偏好设置,状态栏下就可以看见了
  5. 在Xcode中,选择你的手机作为目标设备,Run运行就可以了React Native 真机调试的json文件-1

###Android 真机调试

  1. 在 Android 设备上打开 USB debugging 并连接上电脑启动调试。

  2. 在真机上运行的方法与在模拟器上运行一致,都是通过 react-native run-android 来安装并且运行你的 React Native 应用。

  3. 如果不是 Android 5.0+ (API 21) ,那么就没办法通过 adb reverse 进行调试,需要通过 WiFi 来连接上你的开发者服务器
  4. 让调试用电脑和你的手机必须处于相同的 WiFi 网络中下 打开震动菜单 (摇动设备)->前往 Dev Settings->选择 Debug server host for device->输入调试用电脑的局域网IP->点击 Reload JS

注:因为本人不是安卓开发,所以参考http://my.oschina.net/imot/blog/512808

###细节 其实还是有些坑的,这里只说iOS 如开始所说,必须是同一网络下,有时电脑同时开着Wifi和插着网线,建议把网线拔掉,但是也不排除可以,没有试过,还有就是

jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index.ios" fallbackResource:nil];

这一句千万不能注释,需要注意的就这几点,很简单

D2:React Native import 文件的小技巧 (2016-8-19)

开发中经常需要 import 其他 js 文件,如果需要同时导入一些相关的 js 文件时,可以创建一个索引文件方便引用。

第一步:创建index.js

在 index.js 中 import 相关的 js 文件

'use strict';import * as Type from './network/EnvironmentConst';import Request from './network/RequestManager';import AppContext from './network/AppContext';import ApiServiceFactory from './network/ApiServiceFactory';module.exports = {    ApiServiceFactory,    Type,    Request,    AppContext};

第二步:使用

如果需要使用这些类,只需要导入index文件就可以了~

import {Request, ApiServiceFactory, AppContext, Type} from '../expand/index';

D1:React Native 读取本地的json文件 (2016-8-18)

自 React Native 0.4.3,你可以以导入的形式,来读取本地的json文件,导入的文件可以作为一个js对象使用。

第一步:导入json文件

var langsData = require('../../../res/data/langs.json');

ES6/ES2015

import langsData from '../../../res/data/langs.json'

第二步:使用

如果langs.json的路径正确切没有格式错误,那么现在你可以操作langsData对象了。

Usage

读取langs.json

React Native 读取本地的json文件-1

使用langs.json

React Native 读取本地的json文件-2

@How to fetch data from local JSON file on react native?

About

本文出自《React Native学习笔记》系列文章。

了解更多,可以关注我的:

GitHub 
微博 
http://jiapenghui.com

推荐阅读

  • React Native 学习笔记
  • React Native Awesome(汇聚知识,分享精华):汇集了各类react-native学习资料、工具、组件、开源App、资源下载、以及相关新闻等。
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 睡前吃得太饱怎么办 胰岛素2小时>300怎么办 血清c肽测定高怎么办 体测蛋白质和骨骼肌偏高怎么办 半个月重了十斤怎么办 月经停了2个月怎么办 在练腹肌中腹痛怎么办 越练肌肉越肥怎么办 喘不过气来 心闷怎么办 被气得喘不过气怎么办 健身完头晕想吐怎么办 吃多了反胃头晕怎么办 合同未约定退货货物积压怎么办 运动内衣把胸压平怎么办 经常穿皮鞋脚臭怎么办 买衣服胸围小了怎么办 内衣下胸围太紧怎么办 穿文胸衣服要开怎么办 运动内衣的拉链老来怎么办 胸罩没干急着穿怎么办 跑步时大腿很痒怎么办 胖大腿内侧磨伤怎么办 内衣围带过松怎么办 内衣底围特别紧怎么办 全棉衣服上的油怎么办 高腰牛仔裤腰大了怎么办 新买衣服太硬怎么办 棉麻的衣服发硬怎么办 新衣服太硬怎么办雪纺 衣服硬的咯人怎么办 脖子上的勒痕怎么办 腿上容易出现勒痕怎么办 身上总有内裤印怎么办 内裤穿出了印怎么办 饮水机热水口不出水怎么办 饮水机热水口出水小怎么办 新饮水机热水口出水小怎么办 白钢水桶中间支撑怎么办 17岁想长高应该怎么办 身子瘦但脸胖怎么办 减肥只瘦了胸是怎么办