react-native常见问题及处理办法

react-native 所有的文字显示必须用

<Text></Text>标签包裹

<Scrollview></Scrollview>页面滚动标签

  • react-native与PC不同的的其中一点就是,如果高度高出屏幕高度不会自动撑开,添加滚动条
  • 如果要想页面滚动<Scrollview>就需要添加这个标签
  • 添加<Scrollview>须要指定高宽,不然不会生效
  • 如果<Scrollview>外层标签已指定高宽,则可以给定flex:1属性(官网默认推荐)

<Scrollview></Scrollview>标签如果里面还嵌套有另外一个同样的标签,默认内部的是不会滚动的

  • 如果想要外部内部的<Scrollview></Scrollview>都生效
  • 外部scollview设置scrollEnabled={this.state.scoll}
  • 然后在内部scollview里面的点击函数加上,onPressIn和onPressOut操作
  • onPressIn时设置scoll为false,这样外部scollview就不能滑动了,内部scollview就能滑动了。
  • onPressOut时则设置scoll为true 这样就解决了内外部的滚动冲突问题
  • react-native里面如果要实现阴影效果IOS默认是可以通过样式实现,但是Android要实现需要添加

elevation:(number)

margin或者padding属性,不能像写css那样直接写多个值

  • marginVertical 同时设置marginTop和marginBottom。
  • marginHorizontal 同时设置marginLeft和marginRight。
  • padding也是同样的

在App里面,一般有启动图,引导页,注册页,但是一般引导页,跟注册页,默认是不能返回的,在react-navigation组件中要实现不能返回的页面有两种办法

//替换当前路由
this.props.navigation.replace('被替换的路由’)
//重置路由
import { StackActions, NavigationActions } from 'react-navigation';
const resetAction = StackActions.reset({
  index: 0,
  actions: [NavigationActions.navigate({ routeName: 'Profile' })],
});
this.props.navigation.dispatch(resetAction);
在组件或其他没有props的地方调用路由跳转
  • 创建一个NavigationService.js的文件,里面封装路由的一些方法
  • 在根目录通过ref属性,拿到路由的实例
import { NavigationActions } from 'react-navigation';

let _navigator;
//通过ref属性拿到路由的实例
function setTopLevelNavigator(navigatorRef) {
  _navigator = navigatorRef;
}

function navigate(routeName, params) {
  _navigator.dispatch(
    NavigationActions.navigate({
      routeName,
      params,
    })
  );
}
function back(key){
  _navigator.dispatch(
    NavigationActions.back({
      key
    })
  )
}

// add other navigation functions that you need and export them

export default {
  navigate,
  setTopLevelNavigator,
  back
};
import React, { Component } from 'react';
import StackNavigator from './src/router/StackNavigation/StackNavigation';
import { StatusBar, SafeAreaView,} from 'react-native'
import { createAppContainer } from 'react-navigation';
import NavigationService from './src/utlis/NavigationService';

const Navigator = createAppContainer(StackNavigator);

export default class App extends Component {
  /**
   * SafeAreaView避免文字显示在像iPhone X那样的刘海位置
   * StatusBar全面屏手机沉浸式顶部实现
   * Navigator全局路由分发,实现未注册的组件也可以调用路由方法
   */
  render() {
    return (
      <SafeAreaView style={{ flex: 1 }}>
        <StatusBar backgroundColor={'#DB3F40'} />
        <Navigator
          ref={navigatorRef => {
            NavigationService.setTopLevelNavigator(navigatorRef);
          }}
        />
        <Loading ref={(loading) => { global.loading = loading }}></Loading>
        <Toast ref={(toast) => { global.toast = toast }}></Toast>
      </SafeAreaView>
    )
  }

}

禁用全局console的输出
if (!__DEV__) {
  global.console = {
    info: () => {},
    log: () => {},
    warn: () => {},
    debug: () => {},
    error: () => {}
  };
}
  • React Native 中有一个全局变量DEV用于指示当前运行环境是否是开发环境。我们可以据此在正式环境中替换掉系统原先的 console 实现。
  • 这样在打包发布时,所有的控制台语句就会被自动替换为空函数,而在调试时它们仍然会被正常调用。

绕过校验https

android/bulid.gradle

//targetSdkVersion 的版本号改到26就可以
ext {
        buildToolsVersion = "28.0.3"
        minSdkVersion = 16
        compileSdkVersion = 28
        targetSdkVersion = 28  //  =>26
        supportLibVersion = "28.0.0"
    }

总结使用中遇到的一些问题,以及解决办法,如有写的不正确的,还请指正

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