zoukankan      html  css  js  c++  java
  • React Native知识11-Props(属性)与State(状态)

    原文链接:https://www.cnblogs.com/wujy/p/5853613.html

    一:Props(属性)

    大多数组件在创建时就可以使用各种参数来进行定制。用于定制的这些参数就称为props(属性)。props是在父组件中指定,而且一经指定,在被指定的组件的生命周期中则不再改变

    通过在不同的场景使用不同的属性定制,可以尽量提高自定义组件的复用范畴。只需在render函数中引用this.props,然后按需处理即可。下面是一个例子:

    复制代码
    import React, { Component } from 'react';
    import { AppRegistry, Text, View } from 'react-native';
    
    class Greeting extends Component {
      render() {
        return (
          <Text>Hello {this.props.name}!</Text>
        );
      }
    }
    
    class LotsOfGreetings extends Component {
      render() {
        return (
          <View style={{alignItems: 'center'}}>
            <Greeting name='Rexxar' />
            <Greeting name='Jaina' />
            <Greeting name='Valeera' />
          </View>
        );
      }
    }
    
    AppRegistry.registerComponent('LotsOfGreetings', () => LotsOfGreetings);
    复制代码

    二:State(状态)

    我们使用两种数据来控制一个组件:props和state。props是在父组件中指定,而且一经指定,在被指定的组件的生命周期中则不再改变。 对于需要改变的数据,我们需要使用state。

    一般来说,你需要在constructor中初始化state(译注:这是ES6的写法,早期的很多ES5的例子使用的是getInitialState方法来初始化state,这一做法会逐渐被淘汰),然后在需要修改时调用setState方法。

    假如我们需要制作一段不停闪烁的文字。文字内容本身在组件创建时就已经指定好了,所以文字内容应该是一个prop。而文字的显示或隐藏的状态(快速的显隐切换就产生了闪烁的效果)则是随着时间变化的,因此这一状态应该写到state中。

    复制代码
    import React, { Component } from 'react';
    import { AppRegistry, Text, View } from 'react-native';
    
    class Blink extends Component {
      constructor(props) {
        super(props);
        this.state = { showText: true };
    
        // 每1000毫秒对showText状态做一次取反操作
        setInterval(() => {
          this.setState({ showText: !this.state.showText });
        }, 1000);
      }
    
      render() {
        // 根据当前showText的值决定是否显示text内容
        let display = this.state.showText ? this.props.text : ' ';
        return (
          <Text>{display}</Text>
        );
      }
    }
    
    class BlinkApp extends Component {
      render() {
        return (
          <View>
            <Blink text='I love to blink' />
            <Blink text='Yes blinking is so great' />
            <Blink text='Why did they ever take this out of HTML' />
            <Blink text='Look at me look at me look at me' />
          </View>
        );
      }
    }
    
    AppRegistry.registerComponent('BlinkApp', () => BlinkApp);
    复制代码

    实例2:

    复制代码
    import {
    StyleSheet, Text, View, ViewPropTypes,
    InteractionManager, Animated, Easing, Platform, Image
    } from 'react-native';
    import React, {Component} from 'react';
    import NarBar from "../../components/NarBar";
    import {Actions} from "react-native-router-flux";


    export default class State extends Component {

    constructor(props){
    super(props);
    this.state={
    size:60,
    }
    }
    render() {
    return <View style={{flex: 1}}>
    <NarBar onSelect={() => {
    Actions.pop()
    }} title='下一页'/>
    <Text style={{fontSize:20}}
    onPress={()=>{
    this.setState({
    size:this.state.size+10
    })
    }}
    >
    变大变大
    </Text>

    <Text style={{fontSize:20}}
    onPress={()=>{
    this.setState({
    size:this.state.size-10
    })
    }}
    >
    变小变小
    </Text>
    <Image style={{this.state.size,height:this.state.size,backgroundColor:'red'}}/>
    </View>
    }

    }
    复制代码

     

    注意:箭头函数知识点

    ES6允许使用“箭头”(=>)定义函数。立即执行函数可以写成箭头函数的形式

    复制代码
    // 箭头函数的例子
    ()=>1
    v=>v+1
    (a,b)=>a+b
    ()=>{
        alert("foo");
    }
    e=>{
        if (e == 0){
            return 0;
        }
        return 1000/e;
    }
    复制代码
    复制代码
    var f = v => v;
    上面的箭头函数等同于:
    
    var f = function(v) {
      return v;
    };
    复制代码

    如果箭头函数不需要参数或需要多个参数,就使用一个圆括号代表参数部分。

    var f = () => 5;
    // 等同于
    var f = function () { return 5 };
    var sum = (num1, num2) => num1 + num2;
    // 等同于
    var sum = function(num1, num2) {
      return num1 + num2;
    };

    如果箭头函数的代码块部分多于一条语句,就要使用大括号将它们括起来,并且使用return语句返回。

    var sum = (num1, num2) => { return num1 + num2; }

    由于大括号被解释为代码块,所以如果箭头函数直接返回一个对象,必须在对象外面加上括号。

    其它相关内容可以见ES里面的文章介绍

  • 相关阅读:
    python异常触发及自定义异常类
    python for i in range(x)应用的问题
    季羡林 暮年沉思录
    再谈python的list类型参数及复制
    Python 列表推导式
    JavaScript:垃圾数据是如何自动回收的?
    JavaScript:this的用法
    JavaScript:浅谈闭包及其回收原则
    ES6:async / await ---使用同步方式写异步代码
    五大主流浏览器与四大浏览器内核
  • 原文地址:https://www.cnblogs.com/cui-cui/p/8422814.html
Copyright © 2011-2022 走看看