RN-学习笔记

1. react-native-swiper 轮播组件

参考
http://www.jianshu.com/p/4dba338ef37a

render() {
        if(this.state.swiperShow){
            return(
                
                    
                        
                            
                        
                        
                            
                        
                        
                            
                        

                    
                
            )
        }else {
            return (
                
                    
                
            );
        }
    }
}
  • react-native-swiper在安卓上与TabNavigator共用时不显示内容问题(这里是巨坑,记得填坑)http://blog.csdn.net/qq_31280709/article/details/73441330

  • 让图片充满元素

img2: {
        width: width,
        height:300,
        resizeMode: 'stretch'
    }
2.array.map(callback,[ thisObject]); ( map在这里是映射的意思)
-
- array.map(callback,[ thisObject]);   ( map在这里是映射的意思)
-
callback的参数也类似:
[].map(function(value, index, array) {
    // ...
});
-------------------------------------------------------------------
例一:
map方法的作用不难理解,“映射”嘛,也就是原数组被“映射”成对应新数组。下面这个例子是数值项求平方:
var data = [1, 2, 3, 4];

var arrayOfSquares = data.map(function (item) {
  return item * item;
});

alert(arrayOfSquares); // 1, 4, 9, 16
callback需要有return值
--------------------------------------------------------------------
例二:
 data1 = dataJson.data;
 i++;
 data1.map( (item)=> {
       dataList.push({     //dataList是全局定义的空数组
           key: i,
           value: item
        })
        i++;
 } )
3.验证码倒计时 setInterval() 和 clearInterval()
coutDown() {
        this.setState({
            MainTime:60,
            MainTimeTitle: ''
        });
        this.bb = setInterval( () => {
            var aa = this.state.MainTime - 1;
            if( aa ===0){
                clearInterval( this.bb );
                this.setState({
                    MainTime:'',
                    MainTimeTitle: '重新获取'
                })}else{
                    this.setState({
                        MainTime: aa,
                        MainTimeTitle: ''
                    })
                }
        },1000)
    }
-------------------------------------
 {this.state.MainTime}{this.state.MainTimeTitle}
 

(踩坑) :这样写的话会有个警告(如下,如图):

RN-学习笔记_第1张图片
countDown()中的bb方法一直在执行

(解决方法)如下:

Waring: Can only update a mounted or mounting component. 

分析:可以看到在 countdown方法中每秒中调用一次bb方法去递减秒数,
当组件unmounted之后这个timer并没有停止,所以出现了上面的问题。

--------------------------------------------------------
解决方法:
将每次setInterval返回的ID保存起来,在componentWillUnmount方法中clearInterval
--------------------------------------------------------

完整代码:
    //组件将被卸载
    componentWillUnmount() {
        clearInterval(this.state.timeId)
    }
    //倒计时
    coutDown() {
        this.setState({
            MainTime:60,
            MainTimeTitle: ''
        });
        this.bb = setInterval( () => {
            var aa = this.state.MainTime - 1;
            if( aa ===56 ){
                clearInterval( this.bb );
                this.setState({
                    MainTime:'',
                    MainTimeTitle: '重新获取'
                })}else{
                    this.setState({
                        MainTime: aa,
                        MainTimeTitle: ''
                    })
                }
        },1000)
        this.setState({
            timeId: this.bb
        });
    }

http://blog.csdn.net/tujiaw/article/details/58238975

4.(react-native-image-picker)上传头像 + (modal浮层) +(AsyncStorage.setItem-getItem)

http://www.jianshu.com/p/04dfef54645c

5.两种方式实现城市三级联动 + (react-narive-picker)+ (sectionList高性能的分组列表组件)+ (webview

http://www.jianshu.com/p/ea94c8c1ee44

你可能感兴趣的:(RN-学习笔记)