博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
react状态提升理解
阅读量:4102 次
发布时间:2019-05-25

本文共 1564 字,大约阅读时间需要 5 分钟。

状态提升,就是react帮我们把多个组件需要用到的数据,提升到最近的父组件中统一管理并传给子组件。

各个组件只能管理自己的状态。提升到父组件之后,子组件的就只能使用父组件传过来的props进行渲染,不能控制。
react是自上而下的数据流。并且所有的数据源都在父组件,方便了我们对于bug的排查。

官网的例子有点散,不是很直观,下面根据官网的例子写的一个简单的demo。;

项目创建是用create-react-app,不会的

home.js

import React, {
Component } from "react";import Header from '../../component/header/header.js';import Footer from '../../component/footer/footer';import Sidebar from '../../component/sidebar/sidebar';class Home extends Component {
constructor(props) {
super(props) // strs 为状态提升的唯一数据来源 this.state = {
strs: '', } } changeData = (strs) => {
this.setState ({
strs, }) } render () {
return (
) }}export default Home

header.js

import React, {
Component } from "react";class Header extends Component{
constructor(props){
super(props); this.state = {
} } componentDidMount () {
console.log(this.props); } inpChange = (e) => {
this.props.handleChangeValue(e.target.value) } render () {
return (
{
this.props.title }
) }}export default Header;

home为渲染内容的页面组件,header为input组件。这里实现的效果是在通过header渲染的两个输入框,上面的输入框显示大写字母,下面的输入框显示小写字母,在任意一个输入框输入字母,两个输入框都能都能将值通过onChange触发propshandleChangeValue事件,触发父组件changeData事件来更新父组件的state strs。再将值经过处理渲染到2个子组件。


效果展示:在这里插入图片描述

转载地址:http://pnzsi.baihongyu.com/

你可能感兴趣的文章
element ui 弹窗在IE11中关闭时闪现问题修复
查看>>
vue 遍历对象并动态绑定在下拉列表中
查看>>
Vue动态生成el-checkbox点击无法选中的解决方法
查看>>
python __future__
查看>>
MySQL Tricks1
查看>>
python 变量作用域问题(经典坑)
查看>>
pytorch
查看>>
pytorch(二)
查看>>
pytorch(三)
查看>>
pytorch(四)
查看>>
pytorch(5)
查看>>
pytorch(6)
查看>>
opencv 指定版本下载
查看>>
ubuntu相关
查看>>
C++ 调用json
查看>>
nano中设置脚本开机自启动
查看>>
动态库调动态库
查看>>
Kubernetes集群搭建之CNI-Flanneld部署篇
查看>>
k8s web终端连接工具
查看>>
手绘VS码绘(一):静态图绘制(码绘使用P5.js)
查看>>