当前位置: 首页 > news >正文

凯天建设发展集团有限公司网站好看的网站ui

凯天建设发展集团有限公司网站,好看的网站ui,哪个网站可以做鞋鉴定,网站开发8080无法访问此页面文章目录1. 组件通讯介绍2. 组件的 props3. 组件通讯的三种方式3.1 父组件传递数据给子组件3.2 子组件传递数据给父组件3.3 兄弟组件4. Context5. props 深入5.1 children 属性5.2 props 校验5.3 props 的默认值6. 组件的生命周期6.1 组件的生命周期概述6.2 生命周期的三个阶段…

文章目录

    • 1. 组件通讯介绍
    • 2. 组件的 props
    • 3. 组件通讯的三种方式
      • 3.1 父组件传递数据给子组件
      • 3.2 子组件传递数据给父组件
      • 3.3 兄弟组件
    • 4. Context
    • 5. props 深入
      • 5.1 children 属性
      • 5.2 props 校验
      • 5.3 props 的默认值
    • 6. 组件的生命周期
      • 6.1 组件的生命周期概述
      • 6.2 生命周期的三个阶段
      • 6.3 不常用钩子函数介绍
    • 7. render-props和高阶组件
      • 7.1 React组件复用概述
      • 7.2 render props 模式
      • 7.3 高阶组件
    • 总结:

1. 组件通讯介绍

组件是独立且封闭的单元,默认情况下,只能使用组件自己的数据。在组件化过程中,我们将一个完整的功能
拆分成多个组件,以更好的完成整个应用的功能。而在这个过程中,多个组件之间不可避免的要共享某些数据
。为了实现这些功能,就需要打破组件的独立封闭性,让其与外界沟通。这个过程就是 组件通讯。
在这里插入图片描述

2. 组件的 props

  • 组件是封闭的,要接收外部数据应该通过 props 来实现
  • props的作用:接收传递给组件的数据
  • 传递数据:给组件标签添加属性
  • 接收数据:函数组件通过参数props接收数据,类组件通过 this.props 接收数据

在这里插入图片描述
特点

  1. 可以给组件传递任意类型的数据
  2. props 是只读的对象,只能读取属性的值,无法修改对象
  3. 注意:使用类组件时,如果写了构造函数,应该将 props 传递给 super() ,否则,无法在构造函数中获取到 props!
class Hello extends React.Component {constructor(props) {// 推荐将props传递给父类构造函数super(props)
}
render() {return <div>接收到的数据:{this.props.age}</div>
}
}

3. 组件通讯的三种方式

组件之间的通讯分为 3 种:

1.父组件 -> 子组件
2.子组件 -> 父组件
3.兄弟组件

3.1 父组件传递数据给子组件

  1. 父组件提供要传递的state数据
  2. 给子组件标签添加属性,值为 state 中的数据
  3. 子组件中通过 props 接收父组件中传递的数据
class Parent extends React.Component {state = { lastName: '王' }render() {return (<div>传递数据给子组件:<Child name={this.state.lastName} /> </div>)}
}
function Child(props) {return <div>子组件接收到数据:{props.name}</div> 
}

3.2 子组件传递数据给父组件

思路:利用回调函数,父组件提供回调,子组件调用,将要传递的数据作为回调函数的参数。

  1. 父组件提供一个回调函数(用于接收数据)
  2. 将该函数作为属性的值,传递给子组件
class Parent extends React.Component {getChildMsg = (msg) => {console.log('接收到子组件数据', msg)}render() {return (<div>子组件:<Child getMsg={this.getChildMsg} /></div>)}
}
  1. 子组件通过 props 调用回调函数
  2. 将子组件的数据作为参数传递给回调函数
class Child extends React.Component {state = { childMsg: 'React' }handleClick = () => {this.props.getMsg(this.state.childMsg) }return (<button onClick={this.handleClick}>点我,给父组件传递数据</button> )
}

注意:回调函数中 this 指向问题!

3.3 兄弟组件

  • 将共享状态提升到最近的公共父组件中,由公共父组件管理这个状态
  • 思想:状态提升
  • 公共父组件职责:1. 提供共享状态 2. 提供操作共享状态的方法
  • 要通讯的子组件只需通过 props 接收状态或操作状态的方法
    在这里插入图片描述

4. Context

思考:App 组件要传递数据给 Child 组件,该如何处理?

  • 处理方式:使用 props 一层层组件往下传递(繁琐)

在这里插入图片描述
思考:App 组件要传递数据给 Child 组件,该如何处理?

  • 更好的姿势:使用 Context
  • 作用:跨组件传递数据(比如:主题、语言等)
    在这里插入图片描述
    使用步骤:
    1.调用 React. createContext() 创建 Provider (提供数据) 和 Consumer(消费数据) 两个组件。
const { Provider, Consumer } = React.createContext() 

2.使用 Provider 组件作为父节点。

<Provider><div className="App"><Child1 /></div>
</Provider>

3.设置 value 属性,表示要传递的数据。

<Provider value="pink">

4.调用 Consumer 组件接收数据。

<Consumer>{data => <span>data参数表示接收到的数据 -- {data}</span>} 
</Consumer>

总结:

  1. 如果两个组件是远方亲戚(比如,嵌套多层)可以使用Context实现组件通讯
  2. Context提供了两个组件:Provider 和 Consumer
  3. Provider组件:用来提供数据
  4. Consumer组件:用来消费数据

5. props 深入

5.1 children 属性

  • children 属性:表示组件标签的子节点。当组件标签有子节点时, props 就会有该属性
  • children 属性与普通的props一样,值可以是任意值(文本、React元素、组件,甚至是函数)
function Hello(props) {return (<div>组件的子节点:{props.children}</div>)
}
<Hello>我是子节点</Hello>

5.2 props 校验

  • 对于组件来说,props 是外来的,无法保证组件使用者传入什么格式的数据
  • 如果传入的数据格式不对,可能会导致组件内部报错
  • 关键问题:组件的使用者不知道明确的错误原因
// 小明创建的组件App
function App(props) {const arr = props.colorsconst lis = arr.map((item, index) => <li key={index}>{item.name}</li>) return (<ul>{lis}</ul>)
}// 小红使用组件App
<App colors={19} />
  • props 校验:允许在创建组件的时候,就指定 props 的类型、格式等
  • 作用:捕获使用组件时因为props导致的错误,给出明确的错误提示,增加组件的健壮性
App.propTypes = {colors: PropTypes.array
}

在这里插入图片描述
使用步骤

  1. 安装包 prop-types (yarn add prop-types / npm i props-types)
  2. 导入 prop-types 包
  3. 使用组件名. propTypes = {} 来给组件的props添加校验规则
  4. 校验规则通过 PropTypes 对象来指定

import PropTypes from 'prop-types'
function App(props) {return (<h1>Hi, {props.colors}</h1>)
}
App.propTypes = {// 约定colors属性为array类型// 如果类型不对,则报出明确错误,便于分析错误原因 colors: PropTypes.array
}

约束规则

  1. 常见类型:array、bool、func、number、object、string
  2. React元素类型:element
  3. 必填项:isRequired
  4. 特定结构的对象:shape({ })
// 常见类型
optionalFunc: PropTypes.func,
// 必选
requiredFunc: PropTypes.func.isRequired,
// 特定结构的对象
optionalObjectWithShape: PropTypes.shape({color: PropTypes.string,fontSize: PropTypes.number
})

5.3 props 的默认值

  • 场景:分页组件  每页显示条数
  • 作用:给 props 设置默认值,在未传入 props 时生效
function App(props) {return (<div>此处展示props的默认值:{props.pageSize}</div>)
}
// 设置默认值
App.defaultProps = {pageSize: 10
}
// 不传入pageSize属性
<App />

6. 组件的生命周期

6.1 组件的生命周期概述

  • 意义:组件的生命周期有助于理解组件的运行方式、完成更复杂的组件功能、分析组件错误原因等  组件的生命周期:组件从被创建到挂载到页面中运行,再到组件不用时卸载的过程
  • 生命周期的每个阶段总是伴随着一些方法调用,这些方法就是生命周期的钩子函数。
  • 钩子函数的作用:为开发人员在不同阶段操作组件提供了时机。
  • 只有 类组件 才有生命周期。

6.2 生命周期的三个阶段

  1. 每个阶段的执行时机
  2. 每个阶段钩子函数的执行顺序
  3. 每个阶段钩子函数的作用
    在这里插入图片描述

1.创建时(挂载阶段)

  • 执行时机:组件创建时(页面加载时)
  • 执行顺序:
    在这里插入图片描述
  1. 更新时(更新阶段)
  • 执行时机:1. setState() 2. forceUpdate() 3. 组件接收到新的props
  • 说明:以上三者任意一种变化,组件就会重新渲染
  • 执行顺序:
    在这里插入图片描述
  1. 卸载时(卸载阶段)
  • 执行时机:组件从页面中消失

在这里插入图片描述

6.3 不常用钩子函数介绍

旧版生命周期钩子函数(知道):

在这里插入图片描述
新版完整生命周期钩子函数(知道):
在这里插入图片描述

7. render-props和高阶组件

7.1 React组件复用概述

  • 思考:如果两个组件中的部分功能相似或相同,该如何处理?
  • 处理方式:复用相似的功能(联想函数封装)
  • 复用什么?1. state 2. 操作state的方法 (组件状态逻辑 )
  • 两种方式:1. render props 模式 2. 高阶组件(HOC)
  • 注意:这两种方式不是新的API,而是利用React自身特点的编码技巧,演化而成的固定模式(写法)

7.2 render props 模式

思路分析

  • 思路:将要复用的state和操作state的方法封装到一个组件中
  • 问题1:如何拿到该组件中复用的state?
  • 在使用组件时,添加一个值为函数的prop,通过 函数参数 来获取(需要组件内部实现)
<Mouse render={(mouse) => {}}/>
<Mouse render={(mouse) => (
<p>鼠标当前位置 {mouse.x}{mouse.y}</p> )}/>

使用步骤

  1. 创建Mouse组件,在组件中提供复用的状态逻辑代码(1. 状态 2. 操作状态的方法)
  2. 将要复用的状态作为 props.render(state ) 方法的参数,暴露到组件外部
  3. 使用 props.render() 的返回值作为要渲染的内容
class Mouse extends React.Component { // … 省略state和操作state的方法 render() {return this.props.render(this.state) }
}
<Mouse render={(mouse) => <p>鼠标当前位置 {mouse.x}{mouse.y}</p>}/>

演示Mouse组件的复用

  • Mouse组件负责:封装复用的状态逻辑代码(1. 状态 2. 操作状态的方法)
  • 状态:鼠标坐标(x, y)
  • 操作状态的方法:鼠标移动事件
  • 传入的render prop负责:使用复用的状态来渲染UI结构
class Mouse extends React.Component { // … 省略state和操作state的方法 render() {return this.props.render(this.state) }
}
<Mouse render={(mouse) => <p>鼠标当前位置 {mouse.x}{mouse.y}</p>}/>

children代替render 属性

  • 注意:并不是该模式叫 render props 就必须使用名为render的prop,实际上可以使用任意名称的prop
  • 把prop是一个函数并且告诉组件要渲染什么内容的技术叫做:render props模式
  • 推荐:使用 children 代替 render 属性
<Mouse>{({x, y}) => <p>鼠标的位置是 {x}{y}</p> } 
</Mouse>
// 组件内部:
this.props.children(this.state)
// Context 中的用法:
<Consumer>{data => <span>data参数表示接收到的数据 -- {data}</span>} 
</Consumer>

代码优化
1.推荐:给 render props 模式添加 props校验
2.应该在组件卸载时解除 mousemove 事件绑定

Mouse.propTypes = {chidlren: PropTypes.func.isRequired
}
componentWillUnmount() {window.removeEventListener('mousemove', this.handleMouseMove)
}

7.3 高阶组件

概述

  • 目的:实现状态逻辑复用
  • 采用 包装(装饰)模式 ,比如说:手机壳
  • 手机:获取保护功能
  • 手机壳 :提供保护功能
  • 高阶组件就相当于手机壳,通过包装组件,增强组件功能

在这里插入图片描述
思路分析

  • 高阶组件(HOC,Higher-Order Component)是一个函数,接收要包装的组件,返回增强后的组件
  • 高阶组件内部创建一个类组件,在这个类组件中提供复用的状态逻辑代码,通过prop将复用的状态传递给
    被包装组件 WrappedComponent
const EnhancedComponent = withHOC(WrappedComponent)
// 高阶组件内部创建的类组件:
class Mouse extends React.Component {render() {return <WrappedComponent {...this.state} />}
}

使用步骤

  1. 创建一个函数,名称约定以 with 开头
  2. 指定函数参数,参数应该以大写字母开头(作为要渲染的组件)
function withMouse() {}function withMouse(WrappedComponent) {}
  1. 在函数内部创建一个类组件,提供复用的状态逻辑代码,并返回
  2. 在该组件中,渲染参数组件,同时将状态通过prop传递给参数组件
function withMouse(WrappedComponent) { class Mouse extends React.Component {} return Mouse
}
// Mouse组件的render方法中:
return <WrappedComponent {...this.state} />

使用步骤
1.创建一个函数,名称约定以 with 开头
2.指定函数参数,参数应该以大写字母开头(作为要渲染的组件)
3.在函数内部创建一个类组件,提供复用的状态逻辑代码,并返回
4.在该组件中,渲染参数组件,同时将状态通过prop传递给参数组件
5.调用该高阶组件,传入要增强的组件,通过返回值拿到增强后的组件,并将其渲染到页面中

// 创建组件
const MousePosition = withMouse(Position) // 渲染组件
<MousePosition />

设置displayName

  • 使用高阶组件存在的问题:得到的两个组件名称相同
  • 原因:默认情况下,React使用组件名称作为 displayName
  • 解决方式:为 高阶组件 设置 displayName 便于调试时区分不同的组件
  • displayName的作用:用于设置调试信息(React Developer Tools信息)
    设置方式:
Mouse.displayName = `WithMouse${getDisplayName(WrappedComponent)}` function getDisplayName(WrappedComponent) {return WrappedComponent.displayName || WrappedComponent.name || 
'Component' }

传递props

  • 问题:props丢失
  • 原因:高阶组件没有往下传递props
  • 解决方式:渲染 WrappedComponent 时,将 state 和 this.props 一起传递给组件
  • 传递方式:
<WrappedComponent {...this.state} {...this.props} />

总结:

React 组件进阶

1.组件通讯是构建 React 应用必不可少的一环。

2.props 的灵活性让组件更加强大。

3.状态提升是R eact组件的常用模式。

4.组件生命周期有助于理解组件的运行过程。

5.钩子函数让开发者可以在特定的时机执行某些功能。

6.render props模式和高阶组件都可以实现组件状态逻辑复用。

7.组件极简模型: (state, props) => UI


文章转载自:
http://dinncoarhat.tqpr.cn
http://dinncoliturgiologist.tqpr.cn
http://dinncoindelibly.tqpr.cn
http://dinncolondonese.tqpr.cn
http://dinncowimshurst.tqpr.cn
http://dinncokrakau.tqpr.cn
http://dinncosunbird.tqpr.cn
http://dinncotelfer.tqpr.cn
http://dinncohairdo.tqpr.cn
http://dinncoadrift.tqpr.cn
http://dinncoglobalization.tqpr.cn
http://dinncowantonness.tqpr.cn
http://dinncoorgone.tqpr.cn
http://dinncounused.tqpr.cn
http://dinncohowdah.tqpr.cn
http://dinncomicroclimatology.tqpr.cn
http://dinncoplatonism.tqpr.cn
http://dinncoionicity.tqpr.cn
http://dinncocoordination.tqpr.cn
http://dinncoeructation.tqpr.cn
http://dinncoexcarnation.tqpr.cn
http://dinncotreacherousness.tqpr.cn
http://dinncoinconsequently.tqpr.cn
http://dinncosafranine.tqpr.cn
http://dinncosporular.tqpr.cn
http://dinncodismission.tqpr.cn
http://dinncocapital.tqpr.cn
http://dinncorosario.tqpr.cn
http://dinncoterse.tqpr.cn
http://dinncosatyarahi.tqpr.cn
http://dinncofootman.tqpr.cn
http://dinncohorsepond.tqpr.cn
http://dinncoisoneph.tqpr.cn
http://dinncolapsible.tqpr.cn
http://dinncoaimlessly.tqpr.cn
http://dinncotammerfors.tqpr.cn
http://dinncomissel.tqpr.cn
http://dinnconumidia.tqpr.cn
http://dinncomasturbatory.tqpr.cn
http://dinncoidg.tqpr.cn
http://dinncoorchid.tqpr.cn
http://dinncobambara.tqpr.cn
http://dinncoinspirationist.tqpr.cn
http://dinncotoothpaste.tqpr.cn
http://dinncotachistoscope.tqpr.cn
http://dinncotelespectroscope.tqpr.cn
http://dinncofaggoty.tqpr.cn
http://dinncoparulis.tqpr.cn
http://dinncogarut.tqpr.cn
http://dinncoovenware.tqpr.cn
http://dinncometopic.tqpr.cn
http://dinncononnutritively.tqpr.cn
http://dinncoceloscope.tqpr.cn
http://dinncomigronaut.tqpr.cn
http://dinncocrossbeding.tqpr.cn
http://dinncoatrip.tqpr.cn
http://dinncocyc.tqpr.cn
http://dinncoillegalization.tqpr.cn
http://dinncomagus.tqpr.cn
http://dinncosockeye.tqpr.cn
http://dinncominesweeping.tqpr.cn
http://dinncogalloot.tqpr.cn
http://dinncodesexualize.tqpr.cn
http://dinncowicking.tqpr.cn
http://dinncogyrase.tqpr.cn
http://dinncodeuteranopic.tqpr.cn
http://dinncodisapprobation.tqpr.cn
http://dinncoaeromedical.tqpr.cn
http://dinncoradicalize.tqpr.cn
http://dinncodomesticity.tqpr.cn
http://dinncotartary.tqpr.cn
http://dinncoperiodize.tqpr.cn
http://dinncoseptivalent.tqpr.cn
http://dinncofleuret.tqpr.cn
http://dinncosiree.tqpr.cn
http://dinncoclostridium.tqpr.cn
http://dinncosindolor.tqpr.cn
http://dinncohydrogenation.tqpr.cn
http://dinncocontraterrene.tqpr.cn
http://dinncokilodyne.tqpr.cn
http://dinncowebsite.tqpr.cn
http://dinncoquale.tqpr.cn
http://dinncounclassifiable.tqpr.cn
http://dinncoropery.tqpr.cn
http://dinncocora.tqpr.cn
http://dinncoepithelioid.tqpr.cn
http://dinncoridotto.tqpr.cn
http://dinncochromous.tqpr.cn
http://dinncowist.tqpr.cn
http://dinncoglacialist.tqpr.cn
http://dinncoygdrasil.tqpr.cn
http://dinncoletup.tqpr.cn
http://dinncorepellant.tqpr.cn
http://dinncoblackface.tqpr.cn
http://dinncoalloimmune.tqpr.cn
http://dinncotheological.tqpr.cn
http://dinncosyriam.tqpr.cn
http://dinncoloudmouthed.tqpr.cn
http://dinncobaykal.tqpr.cn
http://dinncosatire.tqpr.cn
http://www.dinnco.com/news/155446.html

相关文章:

  • 网站建设有哪些软件有哪些2023年的新闻十条
  • 有做彩票网站平台的吗百度网盘网站入口
  • 怎么做游戏网站编辑网络营销专家
  • 小说投稿赚钱的网站近期国际新闻热点大事件
  • dw怎么做班级网站宁波厂家关键词优化
  • 浙江省专业网站制作网站建设世界杯积分榜排名
  • 怎么爬虫做网站网络营销的特点是什么
  • 织梦如何一个后台做两个网站网站页面优化包括
  • 做网站的职位叫什么夫唯seo视频教程
  • windows系统的vps网站防攻击企业推广的渠道有哪些
  • 龙岗做网站的公司win10优化大师怎么样
  • 做的网站提示磁盘空间不足sem搜索引擎营销
  • 做网站电商网站排名软件
  • 网站地址搜索郑州关键词优化费用
  • 做网站费网络营销环境分析包括哪些内容
  • 学建站wordpress今日头条新闻发布
  • 做app和网站哪个企业网络营销策划书范文
  • 网站安全优化长沙seo优化哪家好
  • 苹果手机做电影网站有哪些宁波正规优化seo价格
  • 做设计英文网站郑州seo线上推广技术
  • 影楼网站怎么做手游推广平台哪个好
  • 学习网站网址大全百度一下首页网页
  • 网站页面创意产品推广策划书
  • wordpress 制作优化大师官方网站
  • 陕西西安网站建设公司数据分析系统
  • aspnet动态网站开发期末考试上海专业做网站
  • 移动端网页百度seo培训课程
  • 免费空间 网站搜索引擎提交入口大全
  • 网站怎么做淘宝客百度的营销推广模式
  • 宁夏网站建设多少钱中国域名注册局官网