react系列(9)混入mixins

混入(混合)是指定义一个对象,让组件去继承该对象的方法和状态的过程,该对象也被称为混入(混合)对象。若组件和被继承的混合对象具体相同的生命钩子函数将要被执行,则混合对象的函数会优先执行,然后再到组件内相同函数执行,但仅限于生命钩子函数。

另外,组件内不允许有和混合对象相同命名的方法(非生命钩子函数),如例子中的handlAction,否则会报错。ReactClassInterface: You are attempting to define `handlAction` on your component more than once. This conflict may be due to a mixin.

// 混合
var mixinCommon = {
	componentWillMount: function() {
		console.log("mix componentWillMount!"); //优先执行
	},
	handlAction:function(){
		console.log("mix action!"); //该方法不允许再从组件中重构,否则会报错
	}
}
var HelloWorld = React.createClass({
	mixins:[mixinCommon],
	componentWillMount: function() {
		console.log("HelloWorld componentWillMount!"); //仍会执行
	},
	componentDidMount: function() {
      this.handlAction(); //调用mixinCommon的方法
    },
    render: function() {
      return <h1>Hello World!</h1>;
    }
});
ReactDOM.render(<HelloWorld />,document.getElementById("example"));

运行结果:

(贴士)ES6 本身是不包含混入支持的。因此,如果你使用 class 关键字创建组件,那就不能使用混入功能了。我们也发现了很多使用混入然后出现了问题的代码库。因此,我们并不推荐在 ES6 中使用混入。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值