【React入门】React父子组件传值demo
公司一直是前后端分离的,最近集团开始推进中后台可视化开发组件(基于React封装),跟师兄聊起来也听说最近对后台开发人员的前端能力也是越来越重视了。所以作为一名后端,了解下前端的框架对自己也是大有好处的!
首先,博主由于在小公司做过,有一定的前端基础,但是学习React框架的时候还是遇到了一些阻力。因为前端框架的一些思想是和后端完全不同的,特别是React这个面向组件的动态语言框架,用起来非常灵活。
顺便说点闲话,一个优秀的前端待遇会比同级别后端还要高一些, 因为一名优秀的前端不仅要不停的学习不断更迭的新技术外、也要能够熟练地在和运营、测试以及产品撕逼中处理问题。还记得在前后端分离前,撕逼这件事一直是后端同学来面对的。分离后、后端同学只要做一名默默无闻的螺丝钉就可以了。
好了开始正题,首先,官网祭天!
官网:offical website:https://react.docschina.org/
特点:
声明式:只需要改变数据源的数据,就能实现页面数据元素的更新。
组件化:差分成多个可复用的组件,组装自己的页面。
虚拟DOM(对象对应DOM元素),不是总是更新DOM。
根据算法,最小重绘页面,减少更新的区域。
传值Demo:
1、主页面,引用了一个自定义组件>TodoList:
render() {
return (
<TodoList />
);
}
2、看一下自定义组件中的代码:
import React, { Component, Fragment } from 'react'; export default class TodoList extends Component {
static displayName = 'TodoList'; constructor(props) {
super(props);
this.state = {
inputVaule: '',
list: ['默认的第一行', '默认的第二行', '默认的第三行'],
};
} render() {
return (
<div className="page5-page">
<input
value={this.state.inputValue||""}
onChange={this.valueChange.bind(this)}
/>
<button onClick={this.butClick.bind(this)}>submit</button> // 循环list显示
<ul>
{
this.state.list.map((item, index) => {
return (
<li key={index} onClick={this.deleteLi.bind(this,index)} >
{item}
</li>
);
})
}
</ul>
</div>
);
}
//当Input组件中值变动后更新为新的值
valueChange(e) {
console.log(e.target.value);
this.setState({
inputValue: e.target.value,
});
}
//按钮点击事件-添加值
butClick() {
this.setState({
list: [...this.state.list, this.state.inputValue],
inputValue: '',
});
}
//点击事件-删除值
deleteLi(index){
console.log(index);
const listNew = [...this.state.list];
listNew.splice(index, 1)
this.setState({
list: listNew
}); }
}
3、显示效果,上面的代码实现了TODOLIST的增删改查功能:
4、上一步的基础上,抽取循环代码为一个列表组件-Item,这样,组件的结构如图:
5、此时涉及到组件传值的问题,这里要注意,React中,所有传值都是自上而下的:
抽取出的Item组件:
mport React, { Component } from 'react'; export default class Item extends Component {
constructor(props) {
super(props);
// this.clickChild.bind(this)
this.clickChild=this.clickChild.bind(this);
this.state = {
inputValue: '',
test: '',
};
}
render() {
return <li onClick={this.clickChild.bind(this)}>{this.props.content}</li>
}
clickChild(){
this.props.deleteLi(this.props.index);
}
}
6、相应的中层组件,注意组件的传值方式:
<Item content={item}
index={index}
deleteLi={this.deleteLi.bind(this)}
/>
import React, { Component, Fragment } from 'react';
import Item from './Item'; export default class TodoListNewA extends Component {
static displayName = 'TodoList'; constructor(props) {
super(props);
this.state = {
inputVaule: '',
list: ['默认的第一行', '默认的第二行', '默认的第三行'],
};
} render() {
return (
<div className="page5-page">
<input
value={this.state.inputValue||""}
onChange={this.valueChange.bind(this)}
/>
<button onClick={this.butClick.bind(this)}>submit</button>
<ul>
{
this.state.list.map((item, index) => {
return (
<Fragment>
<Item content={item}
index={index}
deleteLi={this.deleteLi.bind(this)}
/>
</Fragment>
);
})
}
</ul>
</div>
);
}
valueChange(e) {
console.log(e.target.value);
this.setState({
inputValue: e.target.value,
});
}
//按钮点击事件-添加值
butClick() {
this.setState({
list: [...this.state.list, this.state.inputValue],
inputValue: '',
});
}
//点击事件-删除值
deleteLi(index) {
console.log(index);
const listNew = [...this.state.list];
listNew.splice(index, 1)
this.setState({
list: listNew,
}); }
}
【React入门】React父子组件传值demo的更多相关文章
- 使用react进行父子组件传值
在单页面里面,父子组件传值是比较常见的,之前一直用vue开发,今天研究了一下react的父子组件传值,和vue差不多的思路,父组件向子组件传值,父通过初始state,子组件通过this.props进行 ...
- React创建组件的方法,组件的props属性、state属性的用法和特点,父子组件传值,兄弟组件传值
创建组件的方法,组件的props属性.state属性的用法和特点,父子组件传值,兄弟组件传值 1.react组件 1.1.创建组件的方法 1.1.1.函数组件 定义一个组件最简单的方式是使用JavaS ...
- 十八、React react-router4.x中:实现路由模块化、以及嵌套路由父子组件传值
一.路由模块化(用字典定义路由,然后循环出来) 1.官方文档参考 [官方文档]https://reacttraining.com/react-router/web/guides/quick-start ...
- 创建组件的方法,组件的props属性、state属性的用法和特点,父子组件传值,兄弟组件传值
1.创建组件的方法 函数组件 class组件 1.1 函数组 无状态函数式组件形式上表现为一个只带有一个 `render()` 方法的组件类,通过函数形式或者 `ES6` 箭头 `functi ...
- Angular 父子组件传值
Angular 父子组件传值 @Input @Output @ViewChild 新建一个头部组件 newsheader 在主组件引用 news 组件,在news组件添加 newsheader 组 ...
- vue 非父子组件传值
/*非父子组件传值 1.新建一个js文件 然后引入vue 实例化vue 最后暴露这个实例 2.在要广播的地方引入刚才定义的实例 3.通过 VueEmit.$emit('名称','数据') 4.在接收收 ...
- 【vue】父组件主动调用子组件 /// 非父子组件传值
一 父组件主动调用子组件: 注意:在父组件使用子组件的标签上注入ref属性,例如: <div id="home"> <v-header ref="he ...
- vue父子组件传值加例子
例子:http://element-cn.eleme.io/#/zh-CN/component/form 上进行改的 父传子:用prop:子组件能够改变父组件的值,是共享的,和父操作是 ...
- Vue中非父子组件传值的问题
父子组件传值的问题,前面已经讲过,不再叙述,这里来说一种非父子组件的传值. vue官网指出,可以使用一个空vue实例作为事件中央线! 也就是说 非父子组件之间的通信,必须要有公共的实例(可以是空的), ...
随机推荐
- 简明Python3教程 1.翻译
这里有许许多多本书不同语言的译本,感谢那些不知疲倦的志愿者们! 如果你想帮助这些译本,请参看下面的关于志愿者和语言的列表,然后决定是要开始一个新的翻译项目还是帮助改进现有的翻译项目. 如果你计划开始一 ...
- 使用FileStream向txt格式的文本文件 "追加" 新内容并读取
原文:使用FileStream向txt格式的文本文件 "追加" 新内容并读取 //得到文件路径. static string filePath = AppDomain.Curren ...
- linux之tail -F命令异常file truncated
使用tail -F收集日志时,经常报出file truncated, 导致日志又重新读取.tail: `test.out' has appeared; following end of new fi ...
- 【转载】使用Docker Hub官方gcc:latest镜像编译C/C++程序以及缩小镜像的方法
摘要:使用Docker Hub官方gcc:latest镜像(1.2GB)编译C/C++程序,以及缩小镜像的方法. 方法1: 在gcc容器里编译C/C++程序 将C/C++代码运行在gcc容器内的最简单 ...
- MVC EF Model First
1 在Models下新建实体数据模型Model.edmx 2 在Model.edmx中点右键建立各个实体,增加Scalar Property 3 空白处点右键,添加关系,勾选增加外键 4 保存Mode ...
- 一个字体,大小,颜色可定义的自绘静态框控件-XColorStatic 类(比较好看,一共19篇自绘文章)
翻译来源:https://www.codeproject.com/Articles/5242/XColorStatic-a-colorizing-static-control XColor Stati ...
- C# 事件详解
1.事件的本质是什么 答:事件是委托的包装器,就像属性是字段的包装器一样 2.为什么有了委托还有有事件 委托可以被访问就可以被执行,事件则只能在类的内部执行 3.事件要怎么声明 a.明一个委托 //委 ...
- 【Linux】PuTTY----------windows访问Linux 快捷方便
第一步:百度PuTTY,下载好后直接运行,界面如下: 第二步:后输入IP:10.45.XX.XX,直接点击open按钮 第三步:输入用户名: 第四步:密码~ 现在,您就可以对你访问的linux设备进行 ...
- Windows 10开发基础——网络编程
主要内容: HttpClient类 Socket通信 WCF通信 HttpClient类 在UWP中可以用来进行网络通信的HttpClient类有两个,System.Net.Http.Htt ...
- QDialog之屏蔽Esc键(简单深刻,要么重写keyPressEvent然后break忽略此事件,要么重写eventFilter然后return,都是为了忽略此事件)
简述 Qt中Esc键会在一些控件中默认的进行一些事件的触发,比如:QDialog,按下Esc键窗口消失.大多数情况下,我们不需要这么做,那么就需要对默认事件进行屏蔽. 简述 源码分析 事件过滤器 事件 ...