您好,欢迎访问一九零五行业门户网

怎样使用React高阶组件

这次给大家带来怎样使用react高阶组件,使用react高阶组件的注意事项有哪些,下面就是实战案例,一起来看一下。
前段时间在工作中写hybrid页面时遇到了这样的一个场景,公司需要一系列的活动组件,在每个组件注册的时候都需要调用app端提供的一个接口。一开始也考虑了几种方式,包括mixin、组件继承以及react高阶组件。但经过了种种衡量,最后选择使用了高阶组件的做法。
那什么是高级组件?首先你得先了解请求es6中的class只是语法糖,本质还是原型继承。能够更好的进行说明,我们将不会修改组件的代码。而是通过提供一些能够包裹组件的组件, 并通过一些额外的功能来增强组件。这样的组件我们称之为高阶组件(higher-order component)。
1、mixins的缺点
react官方已不推荐使用mixins的技术来实现代码的重用,mixins技术有一系列的缺点,首先mixins会造成命名冲突,我们通过以下的方式来注入mixins:
var mymixins = require('mymixins'); var button = react.createclass({   mixins: [mymixins],      // ... })
如果你需要注入多个mixins,其中一个是自己的,另外的可能是第三方的。那有可能在两个mixins里使用了相同名称的方法,这会使得其中的一个不起作用,而你能做的只有修改其中一个方法的名称。另一方面,一个mixins一开始可能是非常简单的,仅仅需要实现某一个功能,但当业务越加的复杂,需要往其中加入更多的方法的时候,就会变得非常复杂。要深入了解mixins的缺点,可以查看官方博客。
2、组件继承
对于我自己来说这种方法以前使用的比较多,先创建一个basecomponent,在其中实现一系列公共的方法,其后的每个组件都继承于这个组件,但缺点是不够灵活,在基础组件中只能实现一些比较固定的方法,而对于每个组件的定制化会有很大的限制。
3、react高阶组件
由于mixins的一系列缺点,react官方也意识到使用mixins所带来的痛点远远高于技术本身产生的优点,而高阶组件便可以代替mixins,而且当深入之后它还有着更加丰富的用法。
高阶组件(hoc)是react中对组件逻辑进行重用的高级技术。但高阶组件本身并不是react api。它只是一种模式,这种模式是由react自身的组合性质必然产生的。
高阶函数
说到高阶组件,就先得说到高阶函数了,高阶函数是至少满足下列条件的函数:
1、接受一个或多个函数作为输入
2、输出一个函数
在javascript这门函数为一等公民的语言中,高阶函数的使用还是非常之多的,像我们平时的回调函数等等,都用到了高阶函数的知识。我们先来看一个简单的高阶函数
var fun = function(x, y) {   return x + y; }
fun是一个函数,下面我们将整个函数作为参数传递给另一个函数
var comp = function(x, y, f) {   return f(x,y); }
验证一下
comp(1,2,fun) // 3
高阶组件定义
类比高阶函数的定义,高阶组件就是接受一个组件作为参数,在函数中对组件做一系列的处理,随后返回一个新的组件作为返回值。
我们先定义一个高阶组件baseactivity
const baseactivity = (wrappedcomponent) => {  return class extends component {   render() {    return (     <section>      <p>我的包裹组件</p>      <wrappedcomponent />     </section>         )   }  } }
组件接受一个被包裹的组件作为参数,返回了一个经过处理的匿名组件。
在其他组件中使用这个高阶组件
class example extends react.purecomponent {  constructor(props) {   super(props);   this.state = {    width: '100%',    height: '100%'   }  }  componentwillmount() {   if ((navigator.useragent.match(/(phone|pad|pod|iphone|ipod|ios|ipad|android|mobile|blackberry|iemobile|mqqbrowser|juc|fennec|wosbrowser|browserng|webos|symbian|windows phone)/i))) {    return;   } else {    this.setstate({     width: '375px',     height: '640px'    })   }  }  render() {   let { width, height } = this.state;   return (    <p classname="activity">     <p classname="activity-content" style={{ width, height }}>      <button classname="btn">参加活动</button>     </p>    </p>   )  } } export default baseactivity(example);
具体用法就是在export 组件的时候,使用baseactivity函数来包裹这个组件,看下输出的react dom内容
在example组件外面包裹了一个匿名组件。
参数
既然高阶组件是一个函数,我们就可以向里面传递我们需要的参数
const baseactivity = (wrappedcomponent, title) => {  return class extends component {   render() {    return (     <section>      <p>{title}</p>      <wrappedcomponent />     </section>         )   }  } }
在example中这样export
export default baseactivity(example, '这是高阶组件的参数');
我们看下输出的react dom
可以看到参数已经传递进去了。
当然还可以这样用(柯里化)
const baseactivity (title) => (wrappedcomponent) => {  return class extends component {   render() {    return (     <section>      <p>{title}</p>      <wrappedcomponent />     </section>         )   }  } }
在example中这样export
export default baseactivity('这是高阶组件的参数')(example);
这种用法在ant-design的表单以及redux的connect中我们都可以看到
// ant const wrappeddemo = form.create()(demo) // redux export default connect(mapstatetoprops, mapdispatchtoprops)(counter)
高阶组件还可以扩展原组件的props属性,如下所示:
const baseactivity (title) => (wrappedcomponent) => {  return class extends component {   render() {    const newprops = {      id: math.random().tostring(8)    }    return (     <section>      <p>{title}</p>      <wrappedcomponent {...this.props} {...newprops}/>     </section>    )   }  } }
看下输出的react dom
高阶组件的缺点
高阶组件也有一系列的缺点,首先是被包裹组件的静态方法会消失,这其实也是很好理解的,我们将组件当做参数传入函数中,返回的已经不是原来的组件,而是一个新的组件,原来的静态方法自然就不存在了。如果需要保留,我们可以手动将原组件的方法拷贝给新的组件,或者使用hoist-non-react-statics之类的库来进行拷贝。
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
如何使用js获取modelandview值
如何使用jquery做出文字超过规定行数自动加省略号
以上就是怎样使用react高阶组件的详细内容。
其它类似信息

推荐信息