创建组件的方法,组件的props属性、state属性的用法和特点,父子组件传值,兄弟组件传值

1、react组件

1.1、创建组件的方法

  1.1.1、函数组件

  定义一个组件最简单的方式是使用JavaScript函数

function fn(props){
return <h1>Hello,{props.name}</h1>;
}
该函数是一个React组件,它接收一个单一的 " props " 对象并返回了一个React 元素。我们之所以称这种类型的组件为函数组件

  1.1.2、类组件

//引入react模块
import React from 'react';
//声明子组件son
class R extends React.Component {//重写方法render
render() {
return (
// 模板字串
<React.Fragment>
{/* jsx */}
          <h1>hello,{props.name}</h1> 
</React.Fragment>
);
}
}

1.2组件的props属性

  先在组件上通过自定义属性赋值

  函数组件中,在函数上定义形参props,在函数中 props.属性名

function name(props) {
console.log(props)//输出‘Tom’
}

  类组件中,通过 this.props.属性名

class Rea extends React.Component {
render() {
return (
<React.Fragment>
{console.log(this.props.name)}
{/* 输出’Tom‘ */}
</React.Fragment>
);
}
}

作用:在组件之间进行传值

特点:无论是使用函数或是类来声明一个组件,它不能修改它自己的props值。是只可读不可写

1.3组件的state属性

  state的使用

//引入react模块
import React from 'react'
class Act extends React.Component {
constructor(){
super()
this.state={
name:'lxr'
}
}
render() {
return (
<React.Fragment>
{console.log(this.state.name)}
{/* 这里输出name值为’lxr‘ */}
</React.Fragment>
);
}
}

  通过修改状态来更改name值

//引入react模块
import React from 'react'; class Act extends React.Component {
constructor(){
super()
this.state={
name:'lxr'
}
}
update(){
//重新设置name值
this.setState({
name:'rlh'
})
}
render() {
return (
<React.Fragment>
{/* 这里绑定事件 */}
<button onClick={this.update.bind(this)} >点击</button>
{console.log(this.state.name)}
</React.Fragment>
);
}
}

  state是组件内独有的,外部无法向内部传递state,也无法直接改变state的值

而改变state是使用React组件基类中的一个自带函数:

this.setState({
...
});

  使用这个函数之前一定要注意this的作用域,箭头函数中的this指向外部this,而普通函数中的this指向函数本身

 

2、react传值

2.1、父传子

//引入react模块
import React from 'react';
//引入Son模块
import Son from './Son'; //声明父组件father
class Father extends React.Component {
//父类方法render
render() {
return (
<React.Fragment>
{/* 使用子模块Son 并把mess传给子组件,方法名为mess */}
<Son mess='父组件传来的' />
</React.Fragment>
);
}
} export default Father;
//引入react模块
import React from 'react';
//声明子组件son
class Son extends React.Component { //子类方法render
render() {
return (
<React.Fragment>
{/* 用构造方法里的props来调父组件传来的mess */}
{console.log(this.props.mess)}
</React.Fragment>
);
}
}
//向外暴露
export default Son

  子组件输出父组件传来的值

2.2、子传父

//引入react模块
import React from 'react';
//引入Son模块
import Son from './Son'; //声明父组件father
class Father extends React.Component {
//父组件的father方法
father(msg){
console.log(msg)
} //父类方法render
render() {
return (
<React.Fragment>
{/* 使用子模块Son 把父组件的father方法传给子组件*/}
<Son father= {this.father.bind(this)} />
</React.Fragment>
);
}
}
//向外暴露
export default Father;
//引入react模块
import React from 'react';
//声明子组件son
class Son extends React.Component { //子类方法render
render() {
return (
<React.Fragment>
{/* 调用父组件传来的father方法 */}
{this.props.father('来自子组件传来的数据')}
</React.Fragment>
);
}
}
//向外暴露
export default Son

父组件输出子组件传来的值

2.3、兄弟相传

  • 父组件
//引入react模块
import React from 'react';
//引入Son模块
import Son from './Son';
//引入Son0模块
import Son0 from './Son0'; //声明父组件father
class Father extends React.Component {
constructor(){
super()
//给state定义mess为空值
this.state={
mess:''
}
}
//父组件的father方法
father(msg){
//控制台输出子组件传来的数据
// console.log(msg)//输出:来自son的数据
//给状态里的mess设置值
this.setState({
mess:msg
})
} //父类方法render
render() {
return (
<React.Fragment>
{/* 使用子模块Son 把父组件的father方法传给子组件*/}
<Son father= {this.father.bind(this)} />
{/* 把子组件son传来的值再传给子组件son0 */}
<Son0 mess={this.state.mess} />
</React.Fragment>
);
}
}
//向外暴露
export default Father;
  • 子组件1
//引入react模块
import React from 'react';
//声明子组件son
class Son extends React.Component {
//子组件的son方法
son(){
//使用father传来的方法,并返回数据
this.props.father('来自son的数据')
}
//子类方法render
render() {
return (
<React.Fragment>
{/* 绑定click时间点击的时候调用son方法 */}
<button onClick={this.son.bind(this)}>来自子组件的按钮</button>
</React.Fragment>
);
}
}
//向外暴露
export default Son
  • 子组件2
//引入react模块
import React from 'react';
//声明子组件son0
class Son0 extends React.Component {
//子类方法render
render() {
return (
<React.Fragment>
{console.log(`我是Son0 这是:${this.props.mess}`)}
</React.Fragment>
);
}
} export default Son0;

当我点击button按钮的时候

son0.js输出来自son.js的数据

      

       

     

  

React创建组件的方法,组件的props属性、state属性的用法和特点,父子组件传值,兄弟组件传值的更多相关文章

  1. react中直接调用子组件的方法(非props方式)

    我们都知道在 react中,若要在父组件调用子组件的方法,通常我们会采用在父组件定义一个方法,作为props转给子组件,然后执行该方法,可以获取到子组件传回的参数以得到我们的目的. 显而易见,这个执行 ...

  2. ReactNative之从HelloWorld中看环境搭建、组件封装、Props及State

    开篇呢,先给大家问个好,今天是中秋节,祝大家中秋节快乐!!虽然是中秋节,但是木有回家还是总结一下知识点写写博客吧,想着昨天总结一下的,但是昨天和几个同学小聚了一下,酒逢知己总是千杯少呢,喝的微醺不适合 ...

  3. 创建组件的方法,组件的props属性、state属性的用法和特点,父子组件传值,兄弟组件传值

    1.创建组件的方法   函数组件   class组件 1.1 函数组 无状态函数式组件形式上表现为一个只带有一个 `render()` 方法的组件类,通过函数形式或者 `ES6` 箭头 `functi ...

  4. React中props和state相同点和不同点

    朋友们,我想死你们了,最近这几天忙着和病魔作斗争所以没怎么写博客,今天感觉好点了,赶紧来写一波,就是这木敬业. 今天我们来讨论讨论props和state相同点和不同点 首先我来概要说明一下这两者 pr ...

  5. react创建组件的几种方式及其区别

    react创建组件有如下几种方式 ①.函数式定义的无状态组件 ②.es5原生方式React.createClass定义的组件   ③.es6形式的extends React.Component定义的组 ...

  6. React创建组件的三种方式及其区别

    内容转载于http://www.cnblogs.com/wonyun/p/5930333.html React推出后,出于不同的原因先后出现三种定义react组件的方式,殊途同归; 具体的三种方式: ...

  7. 四、React创建组件、 JSX使用、绑定数据、引用图片方式、数组(列表)循环输出

    接:https://www.cnblogs.com/chenxi188/p/11702799.html 用上节建好的my-app项目: my-app/ README.md node_modules/ ...

  8. react 中子组件调用父组件的方法

    1.在父组件中定义方法,并绑定在子组件上 // 在子组件中调用父组件中的方法 import React,{Component} from 'react'; import Child from './c ...

  9. React创建组件的不同方式(ES5 & ES6)

    一. 首先缕清楚React.createElement.React.createClass.React.Component之间的关系 1. React.createElement(HTML eleme ...

随机推荐

  1. Prometheus PromSQL 常用资源

    Prometheus PromSQL 常用资源 PromSQL 使用 运算乘:*除:/加:+减:- 函数 sum() 函数:求出找到所有value的值 irate() 函数:统计平均速率 by (标签 ...

  2. 【08】Jenkins:关于发布

    写在前面的话 Jenkins 对于我们用户而言,可能中间会有不同的需求,比如自动构建,接口测试,代码质量检测.但其实我们的最终目的还是打包上线.当然,各个公司的项目开发语言会不一样,但是总体而言发布方 ...

  3. Dozer JAVA的POJO 映射工具

    Dozerhttp://www.manongjc.com/article/50949.html JAVA的映射工具 BeanUtils dozer的使用方法https://blog.csdn.net/ ...

  4. DISK2VHD 转win2008 无法启动

    windows 2008R2物理机,使用微软的DISK2VHD转换成虚拟盘,挂到虚拟机上,无法启动只有光标闪.找来window2008安装盘 选择“修复windows系统”, 调出cmd命令提示符Bo ...

  5. springmvc之静态资源访问不到 -记一次惨痛的经历

    springmvc之静态资源访问不到 -记一次惨痛的经历 问题描述:项目正常启动,可以访问页面,但是无法找到静态资源文件,如css,js等文件资源. 控制台: $ 未定义 页面: GET http:/ ...

  6. windows下查看webp格式图片

    关于webp 时下webp格式日渐势起,主流浏览器(IE: ???)已经开始支持webp,诸多互联网企业(Facebook 和 ebay,国内的有淘宝.腾讯和美团等)都已经在不遗余力的将webp应用到 ...

  7. JS引擎是如何工作的?从调用堆栈到Promise

    摘要: 理解 JS 引擎运行原理. 作者:前端小智 原文:JS引擎:它们是如何工作的?从调用堆栈到Promise,需要知道的所有内容 Fundebug经授权转载,版权归原作者所有. 为了保证可读性,本 ...

  8. Shell基础 -Linux从入门到精通第九天(非原创)

    文章大纲 一.关于shell二.shell进阶(重点)三.学习资料下载四.参考文章   一.关于shell 1. 什么是shell 1.1 shell简介  Shell(外壳) 是一个用 C 语言编写 ...

  9. MySQL Execution Plan--合理利用隐式的业务逻辑

    问题描述 优化过程中遇到一个SQL: SELECT SUM(user_value) FROM user_log ; 其执行计划为: . row *************************** ...

  10. Ubuntu拒绝root用户ssh远程登录

    sudo vim /etc/ssh/sshd_config 找到并用#注释掉这行:PermitRootLogin prohibit-password 新建一行 添加:PermitRootLogin y ...