React Native踩坑日记(一)—— 入门

  • 因为RN版本更新频繁,所以后期每次新建一个工程的时候,都会报类似
    unmet peer dependency的警告,说RN的版本不符合之类的。找了stack over flow和github上面的很多资料,没有招到相应的解决方案。暂时先不管了。因为似乎不影响使用。只是不知道后续会不会需要指定版本来创建项目
  • 如果要修改项目存放的地址,记住,这个项目的父路径不能包含空格或特殊字符,否则Xcode中无法编译通过。这是今天碰到最大的坑。

2017.8.4

知识点

  • state状态机的概念
    在一个类初始化时,在构造函数中必须定义的变量.
构造函数
  • 箭头函数的理解
    =>简单的理解,箭头函数也可以看做一个简单的匿名函数。
    • 函数的左边是参数,右边是表达式,可以看做 () => {return something}.
    • 如果参数为空,用()表示.否则可以用(param1,param2) => {return param1,param2,'3'}
    • 左边的参数可以和右边毫不相关(但是这样没什么意义,如果 不相关,那直接就传空参数就好了)
    • 有时候,右侧的表达式是一个函数,例如() => this.someFunction,虽然这样写不会报错,个人感觉目前为初学阶段,统一右侧加上表达式,改写为
      () => {return this.someFunction;}

      () => {this.someFunction;}

回调的机制 —— 包括如何切换状态机

先说如何切换状态机.指的是在需要的时机,改变this.state中某个变量的值。以下面的代码为例,修改的就是inputNuminputPW

this.state = {inputNum: '',
              inputPW: '',};

修改状态机

  • 必须调用this.setState方法
  • setState参数必须是一个函数变量(可以查看他的函数原型参数),我们这里通常使用箭头函数来传值
this.setState(
    () = {return {inputNum:'neededValue',}}
);

下面是一个示例代码

以我们目前看到的textInput为例来说明

export default class LoginDemo extends Component {
    constructor(props) {
        super(props);
        this.state = {
            inputNum: '',
            inputPW: '',
        };
        this.updatePW = this.updatePW.bind(this);
    }

    updateNum(newText) {
        console.log("设置数字,输入" + newText);
        this.setState(
             () => {return {inputNum:newText,}}
        );
    }

    updatePW(newText) {
        console.log("设置密码,输入" + newText);
        this.setState()
    }

    render() {
        return (
            <View style={styles.container}>
                <TextInput style={styles.inputStyle}
                           selectionColor={'red'}
                           placeholder={"请输入数字\n"}
                           placeholderTextColor={'purple'}
                           onChangeText={
                               (a) => {this.updateNum(a);}
                           }
                />
                <Text style={styles.welcome}>
                    您输入的电话号码 : {this.state.inputNum}
                </Text>
                <Text style={styles.welcome}>
                    您输入的密码 : {this.state.inputPW}
                </Text>
                <TextInput style={styles.inputStyle}
                           maxLength={6}
                           placeholder={"请输入密码\n"}
                           secureTextEntry={true}
                           onChangeText={(newText) => this.updatePW(newText)}
                />
            </View>
        );
    }
}

代码实现的目的是在 TextInput中输入字符串,同时通过监听函数onChangeText去更新另一个Text的显示值.

  • 这里就涉及到了,我改变了状态机变量 inputNum,如何使他生效的问题。
    修改inputNum要调用到设置状态机的函数方法.this.setState(() => {return {inputNum:'something'}})
    根据书上的理论,修改状态机,虽然从JS的代码上来说,通过this.state = someValue是可行的,但是RN中并不能识别这种赋值方式。
  • 回调函数onChangeText的参数是一个函数变量。这里就带来了一个问题—— {}中放的究竟是怎么样的函数,才算合适?
    • onChangeText={this.updateNum} —— 直接传递函数。
      理论上似乎可行,书中写的也是说可行的。但是实际运行的时候会报错,
      截图

从报错的原因来看,应该是onChangeText要求{}中传递的参数是一个函数,但是实际上,调用 this.updateNum的时候,他是将this.setState的执行结果返回了。

  • onChangeText={this.updateNum(newText)}
    这种方式不用讨论,肯定不行。首先newText未定义,其次就算newText是一个已知数,那么执行的结果仍然不是一个函数。
    如果将newText换成一个具体的字符串'string',执行的结果会造成死循环.
  • 从上一点来看,如何将一个带形参的函数传递进去,变成了应该要解决的问题。因此就要用到箭头函数
onChangeText={(a) => {this.updateNum(a);}}


真机调试

鉴于上面的介绍,我在两个平台调试时,并不以 react-native run-iosreact-native run-android命令来运行,而是分别使用XcodeAndroid Studio来做。

Xcode没什么好说了,但是安卓的真机调试有一个坑。
真机调试首次加载可能会报错:
java.lang.RuntimeException: Unable to load script from assets 'index.android.bundle'. Make sure your bundle is packaged correctly or you're running a packager server.

这是因为还没有在手机上设置 server 和 port,摇一摇启动设置页面,点击 DevSettings -> Debug server host & port for device -> 输入 [本机ip]:8081,本机 ip 可用 ifconfig 命令查看。输入完后返回,再摇一摇然后点击 Reload 即可。

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

推荐阅读更多精彩内容