其实高阶组件是一个将组件写的更灵活的方式,他的应用场景在业务开发中会非常多样
这里 我们演示一种 主要还是解决问题的思想最重要 或者是 这个不叫解决问题 而是设计组件结构的思路
我们来模拟一个场景
在src下有一个 components 文件夹目录
在 components 下有一个 banner.jsx组件 参考代码如下
import React,{ Component } from 'react';
class Banner extends Component {
constructor() {
super();
this.state = {
loading: true,
banner: null
}
}
componentDidMount() {
fetch("http://iwenwiki.com/api/blueberrypai/getIndexBanner.php").then(res =>
res.json()).then(banner => {
this.setState({
loading: false,
banner: banner
})
})
}
render() {
if(this.state.loading) {
return (
<div>loading</div>
)
} else {
return (
<h1> {this.state.banner.banner[0].title }</h1>
)
}
}
}
export default Banner;
然后 在components下有一个 chengpin.jsx组件 参考代码如下
import React,{ Component } from 'react';
class Chengpin extends Component {
constructor() {
super();
this.state = {
loading: true,
chengpin: null
}
}
componentDidMount() {
fetch("http://iwenwiki.com/api/blueberrypai/getChengpinInfo.php").then(res =>
res.json()).then(chengpin => {
this.setState({
loading: false,
chengpin: chengpin
})
})
}
render() {
if(this.state.loading) {
return (
<div>loading</div>
)
}else{
return (
<h1> {this.state.chengpin.chengpinInfo[0].title}</h1>
)
}
}
}
export default Chengpin;
其实 两个组件写的写法 基本就是一样的
只是调用的接口 和使用的字段不一样而已 像这么相似的东西 我们真的没必要写两个组件来处理 直接一个高阶组件就行了
我们先将这两个组件删了
然后 我们在components目录下创建 withFetch.jsx组件
参考代码如下
import React from 'react'
const withFetch = (url) => (View) => {
return class extends Component {
constructor() {
super();
this.state = {
loading: true,
data: null
}
}
componentDidMount() {
fetch(url)
.then(res => res.json())
then(data => {
this.setstate({
loading: false,
data: data
});
})
}
render() {
if(this.state.loading) {
return(
<div>loadding....</div>
)
}else{
return <View data={this.state.data }></View>
}
}
}
}
export default withFetch;
这样 我们的一个高阶组件就写好了 然后 讲解一下
我们 方法 第一个参数 接收一个url参数 这个参数 用来控制fetch网络请求的地址 也可以理解为控制他去调哪个接口
然后 第二个参数 是一个组件
最后 将请求回来的数据 给了组件的data参数
然后 在components下创建 componentTransfer.jsx文件 用于使用高阶组件
import React from "react"
import withFetch from "./withFetch"
const Chengpin = withFetch("http://iwenwiki.com/api/blueberrypai/getChengpinInfo.php")(props =>{
return(
<div>
<h1> {props.data.chengpinInfo[0].title}</h1>
</div>
)
})
const Banner = withFetch("http://iwenwiki.com/api/blueberrypai/getIndexBanner.php")(props =>{
return(
<div>
<h1>{ props.data.banner[0].title } </h1>
</div>
)
})
let data = {
Chengpin: Chengpin,
Banner: Banner
}
export default data;
这样 我们就将 url作为了 参数 然后 第二个参数 现写的 代码结构 通过接到的 data参数来处理组件内部 然后再传给高阶组件 去渲染
这个写法就会使我们的多组件项目简化很多
最后 修改 src目录下的 App.js 代码如下
import './App.css';
import React from "react";
import ComponentTransfer from "./components/componentTransfer";
export default class App extends React.Component{
constructor(props){
super(props);
this.state = {
}
}
render(){
return (
<div>
<ComponentTransfer.Chengpin/>
<ComponentTransfer.Banner/>
</div>
)
}
}
运行结果如下
大家可以照着写一次 体会一下这种关联渲染的逻辑 用好了 可以让你的项目组件布局简便非常多 组件越多发挥空间越大