ReactNative实战

2019-02-26  本文已影响0人  许久以前

布局

RN的布局思路其实就是Flex布局,关于Flex布局,如果不熟悉的,可以去学习一下Flex布局

先看一下这个电影列表的例子:

image

布局很简单,整体上是水平布局,然后右边里面又是一个垂直布局:

image

外层的container设置主轴flexDirection为横向布局;rightStyle的主轴设置为column垂直方向布局。

image

TouchableOpacity是RN内置的可点击容器,包裹在这个容器的内容均可设置一个onPress()事件。React Native提供了3个组件来做这件事。

1.TouchableHighlight:高亮触摸,用户点击时,会产生高亮效果。

2.TouchableOpacity:透明触摸。用户点击时,点击的组件会出现透明效果。

3.TouchableWithoutFeedback:无反馈性触摸。用户点击时无任何视觉效果。

动态变量:state

RN 变量分两种:props和state。props一般是不变的属性。

而变化的属性则需要使用state。

比如下面滚动scrolllist, 根据滚动距离,动态改变导航栏的透明度:

image image

首先,我们在构造函数(初始化)声明一个state:

this.state = {

headOpactiy:'rgba(28,48,68,0)', //这里初始化一个背景色,第四个参数表示alpha

}

然后在监听滚动的函数里根据滚动距离,计算alpha值:

image

上述方法最后一句很重要,表示要重新设置state变量的值:

this.setState({headOpactiy:color});

这句话执行后,会自动触发render()方法将UI重新绘制更新。这就是React的精华所在。

最后我们看render()里面相关设置背景色的代码:

image

这样,就实现了滚动时不断改变导航栏的透明度的需求。核心就是利用了state的值变化自动执行render()UI重新渲染来改变UI的。

RN的生命周期

RN 页面其实跟客户端一样,都有生命周期的概念,下面我们可以了解一下RN的生命周期的主要方法:

1.constructor(props) 类似于iOS的init()

2.componentWillMount() 类似于iOS的 viewWillAppear()

3.componentDidMount() 类似于iOS的 viewDidAppear()

3.componentWillUpdate()

4.componentDidUpdate()

5.componentWillUnmount()//页面即将移除,类似viewWillDisAppear()

可以看到,其实生命周期大致和客户端的差不多,学习的时候可以和客户端相应的方法联系起来看,就很好理解了。

RN的网络请求

fetch(url,{params})...

这只是简单的api, 实战项目中,网络请求都需要单独封装成一个网络层。这里贴一下我自己项目中的核心方法:

//网络请求
    async request(url, params) {
        await this.readToken();
        return new Promise(function(resolve, reject){
            let fullUrl = baseUrl + url;
            fetch(fullUrl, {
                method : 'POST',
                headers : header,
                body : JSON.stringify(params),
            })
            .then(response => response.json())
            .then(function(respJson){
                let respData = respJson;
                if (respJson.status === '000000') {
                    respData.success = true;
                }else {
                    respData.success = false;
                    if (respJson.status === '000003' ||
                        respJson.status === '010010') {
                        respData.logout = true;
                    }else {
                        respData.logout = false;
                        if (respJson.status === '777777') {
                            respData.showAlert = true;
                        }else {
                            respData.showAlert = false;
                        }
                    }
                }

                resolve(respData);
            })
            .catch(function(error){
                //Alert.alert('error');
                reject(error);
            });
        });
    }

这里用到了Promise语法,PromiseES6以后推出的语法,它的好处是在处理多次异步嵌套的时候非常管用。特别推荐大家去学习,同样还是推荐阮一峰老师的博客ES6语法语法教程:ECMAScript 6 入门.

其实,要讲的还有很多,可以很多真的不知如何去描述,后面有空再贴出来我的项目github地址(由于现在还没上传github,等上传了再来更新)。

最后,希望感兴趣的小伙伴交流~

上一篇 下一篇

猜你喜欢

热点阅读