学习RN的学习笔记,记录下来分享于你们~react
来源: 官网 + 其余资料
复制代码
React Native 中的尺寸都是无单位的,表示的是与设备像素密度无关的逻辑像素点(设备独立像素)。android
import React, { Component } from 'react';
import { AppRegistry, View } from 'react-native';
export default class FixedDimensionsBasics extends Component {
render() {
return (
<View>
<View style={{width: 50, height: 50, backgroundColor: 'powderblue'}} />
<View style={{width: 100, height: 100, backgroundColor: 'skyblue'}} />
<View style={{width: 150, height: 150, backgroundColor: 'steelblue'}} />
</View>
);
}
}
复制代码
运行在不一样平台回呈现不一样的单位,若是是在android上,100表示100dp,若是100修饰字体,则替换为是100sp。若是是运行在了ios上则100表示100pt。这样确保了咱们的布局在不一样的手机上不会发生变化。ios
通常而言咱们会使用flex:1来指定某个组件扩张以撑满全部剩余的空间。web
若是有多个并列的子组件使用了flex:1,则这些子组件会平分父容器中剩余的空间。若是这些并列的子组件的flex值不同,则谁的值更大,谁占据剩余空间的比例就更大。react-native
RN中的flex布局同咱们往常使用的CSS Flex存在一些不一样(并不彻底同样)。bash
不一样之处服务器
flexDirectionapp
决定咱们布局的排列方向。函数
justifyContent布局
能够决定其子元素沿着主轴的排列方式。
flex-start、center、flex-end、space-around、space-between以及space-evenly。
alignItems
能够决定其子元素沿着次轴(与主轴垂直的轴,好比若主轴方向为row,则次轴方向为column)的排列方式。
flex-start、center、flex-end以及stretch。
flex-wrap
决定咱们的元素可否换行。(也就是是否容许多行显示)
wrap、nowrap
alignSelf
用于设置单独子元素的alignItem对其方式。
auto、flex-start、flex-end、center、stretch。
flex
定义的咱们元素的可伸缩的属性。
import React, {Component} from 'react';
import {Text} from 'react-native';
export default class HelloComponent extends Component {
render () {
return <Text style={{color: '#ddd'}}>hello</Text>
}
}
复制代码
const HelloComponent = () => {
return <Text style={{color: '#ddd'}}>hello</Text>
}
export default HelloComponent
复制代码
var HelloComponent = React.createClass({
render () {
return <Text style={{color: '#ddd'}}>hello</Text>
}
});
module.exports = HelloComponent;
复制代码
在iOS中UIViewController
提供了(void)viewWillAppear:(BOOL)animated
, - (void)viewDidLoad
,(void)viewWillDisappear:(BOOL)animated
等生命周期方法,在Android
中Activity
则提供了 onCreate()
,onStart()
,onResume()
,onPause()
,onStop()
,onDestroy()
等生命周期方法,这些生命周期方法展现了一个界面从建立到销毁的一辈子。
在React 中组件(Component)也是有本身的生命周期方法的。
心得:你会发现这些React 中组件(Component)的生命周期方法从写法上和iOS中UIViewController的生命周期方法很像,React 为每一个状态都提供了两种处理函数,will 函数在进入状态以前调用,did 函数在进入状态以后调用。
getInitialState:
在组件挂载以前调用一次,好比咱们一般在这里初始化咱们的state。componentWillMount
: 服务器端和客户端都只调用一次,在初始化渲染执行以前马上调用。componentDidMount()
: 初始化渲染完成以后调用,只调用一次,仅客户端有效(服务器端不会调用)。componentWillReceiveProps(object nextProps)
: 在组件接收到新的 props 的时候调用。在初始化渲染的时候,该方法不会调用。
用此函数能够做为 react 在 prop 传入以后, render() 渲染以前更新 state 的机会。老的 props 能够经过 this.props 获取到。在该函数中调用 this.setState() 将不会引发第二次渲染。
shouldComponentUpdate(object nextProps, object nextState)
:在接收到新的 props 或者 state,将要渲染以前调用。
该方法在初始化渲染的时候不会调用,在使用 forceUpdate 方法的时候也不会。若是肯定新的 props 和 state 不会致使组件更新,则此处应该 返回 false。
心得:咱们能够借助该方法来实现一些优化,好比能够根据新的props和state来决定是否须要从新渲染页面
componentWillUpdate(object nextProps, object nextState):
在接收到新的 props 或者 state 以前马上调用。
注意:你不能在该方法中使用 this.setState()。若是须要更新 state 来响应某个 prop 的改变,请使用 componentWillReceiveProps。
componentDidUpdate(object prevProps, object prevState):
在组件的更新已经同步到 DOM 中以后马上被调用。
使用该方法能够在组件更新以后操做 DOM 元素。
componentWillUnmount:
在组件从 DOM 中移除的时候马上被调用。
在该方法中执行任何须要的清理,好比无效的定时器,或者清除在 componentDidMount 中建立的 DOM 元素。
<Text style={{color: '#ddd'}}>hello</Text>
复制代码
import {Text,StyleSheet} from 'react-native';
export default class HelloComponent extends Component {
render () {
return <Text style={styles.container}>hello</Text>
}
}
const styles = StyleSheet.create({
container: {
backgroundColor: '#eae7ff',
flex: 1
}
});
复制代码