react-native 开发中碰到的问题总结

前段时间接触了一点RN的开发,总结了以下的一些问题以及解决方法

  • AppRegistry.registerComponent('projectName', () => componentName); 一般只会用到一次, projectName 必须和文件夹名字一样.

  • 在iOS上使用http链接的图片地址可能不会显示,解决方案:https://segmentfault.com/a/1190000002933776

  • 图片如果使用网络地址的话,source有固定的格式,资源属性是一个对象,而且必须指定宽高

    <Image source={{'uri': 'https://xxxxx'}} style={{width:193, height: 110}} />
  • 引入本地图片的一些注意点

    使用本地图片,直接require
    require中的图片名字必须是一个静态字符串,不能是一个变量或者表达式
    与网络图片相比,Packager可以得知图片大小了,不需要在代码里再声明一遍尺寸
    如果有banana.ios.jpg和banana.android.jpg,Packager就会根据平台而选择不同的文件
    倍图,可以使用@2x,@3x这样的文件名后缀,来为不同的屏幕精度提供图片

    <Image source={require('./images/banana.jpg')} />
  • StyleSheet.create 用来定义组件的样式
    <Text style={styles.red}>red text</Text>
    <Text style={styles.green}>green text</Text>

    const styles = StyleSheet.create({
        red: {
              fontSize: 40
        },
        green: {
             color: 'green'
        }
    })
    注意要使用驼峰写法
  • 尺寸(宽度和高度):React Native中的尺寸都是无单位的,表示的是与设备像素密度无关的逻辑像素点。

    <View style={{width: 100, height: 100, backgroundColor: 'blue'}}></View>
    
  • flexbox (有个区别,flexDirection的默认方向是 column)

  • 处理文本输入 组件:TextInput 事件: onChangeText

  • 背景图的实现(通过嵌套来实现),不存在 backgroundImage

    <Image source={...}>
        <Text>Inside code</Text>
    </Image>
  • ios 圆角的不好处理 : 不要裸用Image标签,在外面套一层<View>,让borderRadius作用在View标签

  • ScrollView 一个通用的可滚动的容器,可以垂直也可以水平滚动(通过horizontal属性来设置) --- 适合用来显示数量不多的滚动元素

  • FlatList 用于显示一个垂直的滚动列表,其中的元素之间结构近似而仅数据不同,更适于长列表数据,且元素个数可以增删,FlatList并不立即渲染所有元素,而是优先渲染屏幕上可见的元素。FlatList组件必须的两个属性是data和renderItem。data是列表的数据源,而renderItem则从数据源中逐个解析数据,然后返回一个设定好格式的组件来渲染。

  • 网络请求 => Fetch 应用中访问任何网站不会出现跨域,还可以使用ES7的async/await , 或者使用其他第三方库

     async getMoviesFromApi() {
        try {         // 注意这里的await语句,其所在的函数必须有async关键字声明
            let response = await fetch('https://facebook.github.io/react-native/movies.json');            
            let responseJson = await response.json();
                return responseJson.movies;
            } catch(error) {
                console.error(error);
            }
      }
  • class xxx extends Component {} 这种方式必须this.eventName.bind(this)这种方法来正确的绑定this,或者方法直接写成箭头函数,就可以直接用 this.eventName 调用

  • 字符串new Date()会有问题,NaN,最好让后端直接返回时间戳

  • 更改手机statusbar的颜色
    有时候需要做沉浸式的头图,这时候如果ios的statusbar内容颜色为黑色时,则看不到statusbar了,这时候就需要设置一下

    import { StatusBar } from 'react-native'
    render() {
        StatusBar.setBarStyle('light-content', true);
    }
  • 处理证书异常,拦截ssl请求错误q
    @Override
    public void onReceivedSslError(WebView view,SslErrorHandler handler, SslError error) {
        // handler.proceed(); 接受证书
        super.onReceivedSslError(view, handler, error);
        mFail = true;
        showFail();
        String msg = "您访问的页面SSL证书异常";
        mLoadingView.statusToFail(msg);
    } 
  • RN与H5 postMessage 重复的问题,解决方案:

    const patchPostMessageJsCode = `(${String(function() {
      var originalPostMessage = window.postMessage
      var patchedPostMessage = function(message, targetOrigin, transfer) {
          originalPostMessage(message, targetOrigin, transfer)
      }
      patchedPostMessage.toString = function() {
          return String(Object.hasOwnProperty).replace('hasOwnProperty', 'postMessage')
      }
      window.postMessage = patchedPostMessage
    })})();`
    injectedJavaScript={patchPostMessageJsCode}
    
  • react-native run-android 报错
    cd android/
    vim local.properties
    写入以下内容:
    sdk.dir = /Users/USERNAME/Library/Android/sdk
    or
    vim ~/.zshrc
    export ANDROID_HOME=/Users/guest/Library/Android/sdk
    本文首发于 : http://ghost.omeme.me/2017/07/22/react-native-kai-fa-zhong-peng-dao-de-wen-ti-zong-jie/

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,028评论 25 707
  • React Native优秀博客,以及优秀的Github库列表(很多英文资料源自于[awesome-react-n...
    董董董董董董董董董大笨蛋阅读 10,602评论 4 162
  • 持续更新中...... 一套企业级的 UI 设计语言和 React 实现。 https://mobile.ant....
    日不落000阅读 5,679评论 0 35
  • 突然想起要写这篇文章,是因为今天早饭后在林荫满布的校道上漫步,边走边读着村上春树的随笔集《村上朝日堂的卷土重来》。...
    柏小齐阅读 1,390评论 3 22
  • 带“四老上北京” 带四个老人赶北京,让四老六十多年来扬眉吐气了一把,完成了人生最大心愿,唯一遗憾的是没让老...
    鸿雁相伴阅读 403评论 3 6