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

建一个手机网站多少钱网站备案备注信息

建一个手机网站多少钱,网站备案备注信息,泰安做网站优化,福州seo建站react renderProps学习记录1.引入2.改一下呢3.再改一下呢4.总结一下如何向组件内部动态传入带内容的结构(标签)?children propsrender props1.引入 上代码: import React, { Component } from react import ./index.css export default class Parent extends Com…

react renderProps学习记录

  • 1.引入
  • 2.改一下呢
  • 3.再改一下呢
  • 4.总结一下
    • 如何向组件内部动态传入带内容的结构(标签)?
    • children props
    • render props

1.引入

上代码:

import React, { Component } from 'react'
import './index.css'
export default class Parent extends Component {render() {return (<div className="parent"><h3>我是Parent组件</h3><A/></div>)}
}class A extends Component {render() {console.log(this.props);return (<div className="a"><h3>我是A组件</h3></div>)}
}

结果很简单就能猜到
在这里插入图片描述
改一下呢:

import React, { Component } from 'react'
import './index.css'
export default class Parent extends Component {render() {return (<div className="parent"><h3>我是Parent组件</h3><A>Hello !</A></div>)}
}class A extends Component {render() {console.log(this.props);return (<div className="a"><h3>我是A组件</h3></div>)}
}

页面是没有现实Hello !的,但是之前一次的封装NaLink也有传递过标签体内容的,在子组件的props中,children:(内容)
在这里插入图片描述
所以A组件想要展示传递的标签体内容的话,还要改一下A组件

class A extends Component {render() {console.log(this.props);return (<div className="a"><h3>我是A组件</h3>{this.props.children}</div>)}
}

在这里插入图片描述

2.改一下呢

import React, { Component } from 'react'
import './index.css'
export default class Parent extends Component {render() {return (<div className="parent"><h3>我是Parent组件</h3><A><B/></A></div>)}
}class A extends Component {state ={ name:'Mike'}render() {console.log(this.props);return (<div className="a"><h3>我是A组件</h3>{this.props.children}</div>)}
}class B extends Component {render() {console.log('B--render');return (<div className="b"><h3>我是B组件</h3></div>)}
}

A,B组件成了父子组件
在这里插入图片描述
但是这样,如果A组件想传自己的值给B组件,貌似是行不通的

3.再改一下呢

import React, { Component } from 'react'
import './index.css'
import C from '../1_setState'export default class Parent extends Component {render() {return (<div className="parent"><h3>我是Parent组件</h3><A render={(name) => <B name={name}/>} /></div>)}
}class A extends Component {state ={ name:'Mike'}render() {const {name} =this.state;console.log(this.props);return (<div className="a"><h3>我是A组件</h3>{this.props.render(name)}</div>)}
}class B extends Component {render() {console.log('B--render');return (<div className="b"><h3>我是B组件,接收到的name:{this.props.name}</h3></div>)}
}

主要是Parent组件和A组件之间调用要注意:
在这里插入图片描述
Parent组件中,render(当然可以去其他的名字这里)这样写,相当于预留了一个插槽,如果你需要渲染其他组件(例如例子中的B组件),在A组件中调用this.props.render()就可以渲染出B组件,不写的话就不会渲染出B组件

4.总结一下

如何向组件内部动态传入带内容的结构(标签)?

Vue中:
使用slot技术, 也就是通过组件标签体传入结构
React中:
使用children props: 通过组件标签体传入结构
使用render props: 通过组件标签属性传入结构, 一般用render函数属性

children props

<A><B>xxxx</B>
</A>
{this.props.children}
问题: 如果B组件需要A组件内的数据, ==> 做不到 

render props

<A render={(data) => <C data={data}></C>}></A>
A组件: {this.props.render(内部state数据)}
C组件: 读取A组件传入的数据显示 {this.props.data} 
http://www.yayakq.cn/news/324742/

相关文章:

  • 济南网站建设公司哪个好重庆市建设工程信息网安全监督查询
  • 渭南市住建设局网站wordpress一键换链接
  • 网站建设图片如何循环转建行个人网站
  • 不想花钱怎么做网站公司网站开发建设费用
  • 12306网站开发人员个人网站首页设计
  • 帮忙做公司网站商务网站建设目的
  • 长沙网站外包哪家购物网站做的好
  • 全能优化型网站广州网站制
  • 河南网站托管优化普通营业执照有做网站条件吗
  • 做3d同人的网站是什么网站路径
  • 驻马店做网站建设的公司自己怎么开发网站
  • 建网站怎么弄老域名对做网站的
  • 邯郸市住房和城建设局网站wordpress录音
  • 国际网站开发客户的技巧微信公司网站
  • 网站建设百度推广品牌设计公司是做什么的
  • win7怎么做网站域名绑定软件分销系统开发
  • 网站建站制作做好一个网站后
  • 永久个人自助建站交互比较好的网站
  • 禹州市城乡建设局网站海淀发布会
  • 做ppt好的网站有哪些有没有只做软装方案收设计费的网站
  • 电商网站开发设计方法行业网站建设哪家专业
  • 南昌网站建设机构拱墅抖音seo搜索排名推广
  • 电脑手机一体网站谈谈百度和谷歌seo优化的区别
  • 简述企业网站建设的目的有哪些四川住房和城乡建设厅网站电话
  • 学做ps的软件的网站有哪些内容网站手机端做app开发工具
  • 网上做网站网站网站专题欣赏
  • nodejs做的网站长沙百度搜索排名优化
  • 微商城网站建设好么健身房网站建设案例
  • 七星彩的网站怎么做的搜阅网站建设
  • 建站程序员招聘公司网站市场价