react-vue在 React 中运行 Vue
使用Vue 的 Reactivity 系统来观察React组件
使用 react-vue-loader 以在React应用中运行Vue组件
Reactivity 系统
感谢 Vue 层次分明的简洁设计,我们可以很容易的将 reactivity 系统导出(9KB压缩包),并在其上驱动 React 组件
npm install --save react-vue
import React, { Component } from 'react';import Vue, { observer } from 'react-vue';const store = new Vue({ data () { return { count: 0 } }, methods: { increase () { this.count ++; } } }); @observerexport default class Demo extends Component { render () { return <h1 onClick={store.increase}>{store.count}</h1>; } }
Vue组件
npm install --save react-vue react-vue-helper npm install --save-dev react-vue-loader
// One.jsimport React, { Component } from 'react';import Two from './Two';export default class One extends Component { render() { return <Two>Hello Vue</Two>; } }
<!-- Two.vue --><template> <div @click="count++"> <three>{{count}}</three> <slot></slot> </div> </template> <script> import Three from './Three' export default { components: { Three }, data () { return { count: 0 } } }</script>
// Three.jsimport React, { Component } from 'react';export default class Three extends Component { render () { return <span>{this.props.children}</span> } }
评论