zoukankan      html  css  js  c++  java
  • React Native基础教程

      React Native是Facebook开源的框架,用来写Android和iOS移动App。它的口号是 “Learning once, write anywhere”,目的是统一View的编写。我个人也是由于公司需要,故入坑学习,下面就我的理解简单总结下React Native的基本知识。

      需要的预备知识:

        1、学习JavaScript(最新JS核心标准ES6)

        2、简单学习React.js(开发网页)

        3、学习JSX(HTML和JavaScript的混写)

     

      我主要讲一下几个方面:

        1、React Native的基本模板写法

        2、React Native的Flexbox布局

        3、React Native组件化

        4、React Native的生命周期

        5、React Native的数据状态引用

      1、React Native的基本模板写法

     1 'use strict';  =====>(严格模式)
     2 
     3 var React = require('react-native');   =====>(导入模块react-native,关键字是: require)
     4 var {
     5   AppRegistry,
     6   StyleSheet,     =====>(声明要用到得系统组件)
     7   Text,
     8   View,
     9 } = React;
    10 
    11 var FirstApp = React.createClass({   =====>(创建组件名称是:FirstApp, 关键字是createClass)
    12   
    13     render: function() {   =====>(渲染方法, 组件中必须得方法)
    14 
    15         return (
    16 
    17               <View style={styles.container}>                        =====>(这几行就是JSX语法写的)
    18                                                 
    19                   <Text style={{fontSize: 18}}>这是我的第一个React Native APP</Text>   =====>(显示在手机屏幕上的内容在这写) 
    20 
    21               </View>                                    =====>(这里用view包起来,而不是用div)
    22           );
    23     }
    24 });
    25 
    26 var styles = StyleSheet.create( =====>(创建样式,看上面加粗划线的代码,可以在这里定义,也可以直接写在代码里面,如上面的fontSize:18)
    27   container: {
    28       flex: 1,
    29       justifyContent: 'center',      
    30       alignItems: 'center',
    31       backgroundColor: 'orange'
    32     }
    33 });
    34 
    35 AppRegistry.registerComponent('FirstApp', () => FirstApp);   =====>(注册应用,使能够加载运行, FirstApp就是你的App名称)
    36 
    37 module.exports = FirstApp; =====>(导出组件,使能够在别的组件中用)

      最终的打印结果:

        

      2、React Native的Flexbox布局(样式)

      官网的链接:http://facebook.github.io/react-native/docs/flexbox.html#content

      这个比较简单,需自己多实践就行,简单说几个:

      flex: 这个是一个灵活的布局属性,类似比例, 比如你想在一行中定义三张图片,它们的宽比为1:3:2,那么你可以分别设置它们的flex为: 1,3,2

      flexDirection: 这个是设置布局的方向(column 和 row), 视图排列方法是列布局还是行布局

      justifyContent 和 alignItems: 这2个是水平和垂直布局,可以设置水平居中,垂直居中等

      margin(包括marginLeft, marginRight, marginTop, marginBottom) :这个是设置间距(距离左,右, 上, 下)多少

      position (包括absolute和relative): 这个是设置视图的位置是固定的还是相对的

        ......

      3、React Native的组件化, 我们可以分功能来自定义模块写代码,然后把所有模块组合起来,就是一个完整的程序了

     1 'use strict';
     2 
     3 var React = require('react-native');
     4 var {
     5   AppRegistry,
     6   StyleSheet,
     7   Text,
     8   View,
     9 } = React;
    10 
    11 var FirstApp = React.createClass({
    12   
    13     render: function() {
    14 
    15         return (
    16 
    17               <View style={styles.container}>
    18 
    19                   <HelloWorld myText='我是第一' />
    20                   <HelloWorld myText='我是第二' />   =====>(这里三个是引用了下面定义的组件,HelloWorld自动成为FirstApp的子组件)
    21                   <HelloWorld myText='我是第三' />  =====>(myText是传给HelloWorld的属性)
    22 
    23               </View>
    24           );
    25     }
    26 });
    27 
    28 var HelloWorld = React.createClass({
    29   
    30     render: function() {
    31 
    32         return (
    33 
    34               <View>
    35                   <Text style={{fontSize: 20, color: 'red'}}>{this.props.myText}</Text>  
    36               </View>                    =====>(从父组件传过来的myText属性,用this.props.myText接收)
    37           );
    38     }  
    39 });

      最终的打印结果:

      

      

      4、React Native的生命周期

      a、getInitialState: 在组建被挂载之前调用,我们一般在里面定义初始state值

      b、getDefaultProps: 在组件类创建的时候调用一次,然后返回值被缓存下来。如果父组件没有指定 getDefaultProps 中定义的属性,则此处返回的对象中的相应属性将会合并到 this.props

      c、componentWillMount: 服务器端和客户端都只调用一次,在初始化渲染执行之前立刻调用

      d、render: 执行视图的渲染操作

      e、componentDidMount: 在初始化渲染执行之后立刻调用一次,仅客户端有效(服务器端不会调用)

      f、componentWillUnmount: 组件从DOM中移除时调用,一般在次方法进行必要的清理工作

     1 'use strict';
     2 
     3 var React = require('react-native');
     4 var {
     5   AppRegistry,
     6   StyleSheet,
     7   Text,
     8   View,
     9 } = React;
    10 
    11 var FirstApp = React.createClass({
    12     
    13     getDefaultProps: function() {
    14 
    15         console.log('getDefaultProps');
    16 
    17     },
    18 
    19     getInitialState: function() {
    20 
    21         console.log('getInitialState');
    22 
    23         return {
    24 
    25         };
    26     },
    27 
    28     componentWillMount: function() {
    29 
    30         console.log('componentWillMount');
    31     },
    32 
    33     componentDidMount: function() {
    34 
    35         console.log('componentDidMount');
    36     },
    37 
    38     componentWillUnmount: function() {
    39 
    40         console.log('componentWillUnmount');
    41     },
    42 
    43     render: function() {
    44 
    45         console.log('render');
    46 
    47         return (
    48 
    49               <View style={styles.container}>
    50 
    51                   <HelloWorld myText='我是第一' />
    52                   <HelloWorld myText='我是第二' />
    53                   <HelloWorld myText='我是第三' />
    54 
    55               </View>
    56           );
    57     }
    58 });
    59 
    60 var HelloWorld = React.createClass({
    61   
    62     render: function() {
    63 
    64         return (
    65 
    66               <View>
    67                   <Text style={{fontSize: 20, color: 'red'}}>{this.props.myText}</Text>
    68               </View>
    69           );
    70     }  
    71 });
    72 
    73 var styles = StyleSheet.create({
    74   container: {
    75       flex: 1,
    76       justifyContent: 'center',
    77       alignItems: 'center',
    78       backgroundColor: 'orange'
    79     }
    80 });
    81 
    82 AppRegistry.registerComponent('FirstApp', () => FirstApp);
    83 
    84 module.exports = FirstApp;

       最终的打印结果(执行顺序):

      5、React Native的数据状态引用

      a、props: 属性, 用于不同组件之间数值传递,一般是从父组件中传值给子组件,子组件最好不要修改此值,而由父组件来修改,进而更新子组件的值

      还是上面的栗子:

     1 'use strict';
     2 
     3 var React = require('react-native');
     4 var {
     5   AppRegistry,
     6   StyleSheet,
     7   Text,
     8   View,
     9 } = React;
    10 
    11 var FirstApp = React.createClass({
    12 
    13     render: function() {
    14 
    15         console.log('render');
    16 
    17         return (
    18 
    19               <View style={styles.container}>
    20 
    21                   <HelloWorld myText='我是第一' />
    22                   <HelloWorld myText='我是第二' />  =====>(HelloWorld嵌套在FirstApp中,所以HelloWorld自动成为了FirstApp的子组                                    件,myText就是要传递给子组件的属性值)
    23                   <HelloWorld myText='我是第三' />
    24 
    25               </View>
    26           );
    27     }
    28 });
    29 
    30 var HelloWorld = React.createClass({
    31   
    32     render: function() {
    33 
    34         return (
    35 
    36               <View>
    37                   <Text style={{fontSize: 20, color: 'red'}}>{this.props.myText}</Text> =====>(HelloWorld通过props来接收传                                                        过来的myText属性值)
    38               </View>
    39           );
    40     }  
    41 });
    42 
    43 var styles = StyleSheet.create({
    44   container: {
    45       flex: 1,
    46       justifyContent: 'center',
    47       alignItems: 'center',
    48       backgroundColor: 'orange'
    49     }
    50 });
    51 
    52 AppRegistry.registerComponent('FirstApp', () => FirstApp);
    53 
    54 module.exports = FirstApp;

      最终的打印结果:

      

      b、state: 状态,用于同一组件中数据的更新

     1 'use strict';
     2 
     3 var React = require('react-native');
     4 var {
     5   AppRegistry,
     6   StyleSheet,
     7   Text,
     8   View,
     9   TouchableHighlight
    10 } = React;
    11 
    12 var FirstApp = React.createClass({
    13 
    14     getInitialState: function() {
    15 
    16         return {
    17            myValue: '我是初始值'    =====>(设置初始值)
    18         };
    19         
    20     },
    21 
    22     render: function() {
    23 
    24         console.log('render');
    25 
    26         return (
    27 
    28             <View style={{flex: 1, justifyContent: 'center', alignItems: 'center'}}>
    29                 <Text onPress={this.changeText}  =====>(设置文字点击事件,当点击的时候会调用changeText方法)
    30                       style={{fontSize: 30,
    31                               color: 'orange',       =====>(设置文字样式)
    32                               textAlign: 'center'}}>
    33 
    34                                 {this.state.myValue}   =====>(第一次加载数据的时候会获取初始值,用state来获取到初始值)
    35                 </Text>
    36             </View>
    37           );
    38     },
    39 
    40     changeText: function() {
    41 
    42       this.setState({     =====>(这是文字的点击事件, 当我想要更改state初始值的时候,需要用到setState来更改)
    43 
    44           myValue: '我是修改后的值'  =====>(修改初始值myValue,当我修改这里后,系统会自动去调用render函数方法,this.state.myValue会自动更新成最新的值,即:我是修改后的值)
    45       })
    46     }
    47 });
    48 
    49 
    50 AppRegistry.registerComponent('FirstApp', () => FirstApp);
    51 
    52 module.exports = FirstApp;

      最终的打印结果:

                 

      c、ref: 用来指示render中某组件,调用的话就是this.refs.xxx.xxx

     1 'use strict';
     2 
     3 var React = require('react-native');
     4 var {
     5   AppRegistry,
     6   StyleSheet,
     7   Text,
     8   View,
     9   Image,
    10   TouchableHighlight
    11 } = React;
    12 
    13 var FirstApp = React.createClass({
    14 
    15     render: function() {
    16 
    17         console.log('render');
    18 
    19         return (
    20 
    21             <View style={{flex: 1, justifyContent: 'center', alignItems: 'center', backgroundColor: 'yellow'}}>
    22                
    23                <Image
    24                     ref='myImg'
    25                     source={{uri: 'http://pic14.nipic.com/20110522/7411759_164157418126_2.jpg' }} 
    26                     style={{ 350, height: 350}} />    =====>(设置一张图片,并且设置宽高为350)
    27 
    28                <Text onPress={this.changePic} style={{marginTop: 50}}>改变图片的大小</Text> ===>(点击文字,触发事件changePic)
    29             </View>
    30           );
    31     },
    32 
    33     changePic: function() {  =====>(点击文字会调用这个方法)
    34 
    35        console.log('我打印出上面的image的属性来看看:',this.refs.myImg.props); =====>(打印出上面的Image来看看)
    36     }
    37 });
    38 
    39 AppRegistry.registerComponent('FirstApp', () => FirstApp);
    40 
    41 module.exports = FirstApp;

      最终的执行结果:

       

    欢迎加QQ群交流: iOS: 279096195 React Native: 482205185
  • 相关阅读:
    javascript Date format(js日期格式化)
    hcharts 教程
    UVA 10594 Data Flow
    UVA 10746 Crime Wave
    UVA 753 A Plug for UNIX
    UVA 11045 My T-shirt suits me
    UVA 10273 Eat or not to Eat?
    UVA 10806 Dijkstra, Dijkstra.
    UVA 10330 Power Transmission
    UVA 10803 Thunder Mountain
  • 原文地址:https://www.cnblogs.com/GeekStar/p/4940248.html
Copyright © 2011-2022 走看看