props和state

区别:

state和props的区别在于props是不可变的,而state可以根据与用户交互来改变,这就是为什么有些容器组件需要定义state来更新和修改数据,而子组件只能 用props来传递数据。

props的用法  name属性通过 this.props.name 来获取。
var Hello = React.createClass({
  render: function() {
    return <h1>Hello {this.props.name}</h1>;
  }
});
ReactDOM.render(
  <Hello name="zhangsan" />,
  document.getElementById('example')
state和props的组合使用
我们可以在父组件中设置state,并且在子组件上通过props将其传递到子组件上。
import React from "react"
import List  from "../../components/List/index" 

export default class Todo extends React.Component{
    //初始化state数据
    constructor(props,context){
        super(props,context);
        this.state = {
            todos :[]
        }
    }
    render(){
        return(
            <div>  
            //在List组件中,可以通过this.props.todos来获取这个底下state.todos这个数据
                <List todos={this.state.todos}/>
            </div>            
        )
    } 
}
state(状态)
React 把组件看成是一个状态机(State Machines)。通过与用户的交互,实现不同状态,然后渲染 UI,让用户界面和数据保持一致。
React里面,只需要更新组件的state,然后根据新的state重新渲染用户界面(不需要操作DOM)

this.setState 方法就修改状态值,每次修改以后,自动调用 this.render 方法,再次渲染组件。

//初始化state数据
    constructor(props,context){
        super(props,context);
        this.state = {
            name:""
        }
    }
React组件API

设置状态:setState
替换状态:replaceState
设置属性:setProps
替换属性:replaceProps
强制更新:forceUpdate
获取DOM节点:findDOMNode
判断组件挂载状态:isMounted

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值