您当前的位置:首页 > 电脑百科 > 程序开发 > 前端

竟然可以在一个项目中混用 Vue 和 React?

时间:2023-09-14 15:35:08  来源:微信公众号  作者:前端充电宝
React和Vue是前端开发中的两大热门框架,各自都有着强大的功能和丰富的生态系统。然而,你有没有想过,在一个项目中同时使用React和Vue?是的,你没有听错,可以在同一个项目中混用这两个框架!本文就来分享 3 个用于混合使用 React 和 Vue 的工具!

Veaury

Veaury 是一个基于 React 和 Vue3 的工具库,主要用于React和Vue在一个项目中公共使用的场景,主要运用在项目迁移、技术栈融合的开发模式、跨技术栈使用第三方组件的场景。

Veaury的特点如下:

  • 同时支持Vue3和React,方便在一个项目中公共使用。
  • 支持同一个应用中出现的vue组件和react组件的context共享。
  • 支持跨框架的hooks调用,可以在react组件中使用vue的hooks,也可以在vue组件中使用react的hooks。
  • 可以解决React和Vue在公共使用时的代码重复、冗余的问题。
  • 在一个应用中可以随意使用React或者Vue的第三方组件, 比如 antd, element-ui, vuetify。
  • 提供了详细的官方文档,包括英文版和中文版。

Veaury 的文档写的非常详细,这里就不再详细介绍其使用方式了。需要注意的是,Veaury 并不支持 Vue 2,如果需要使用Vue 2,可以使用下面要介绍的工具库。

Githubhttps://github.com/devilwjp/veaury。

Vuera

Vuera 是一个用于在 Vue 应用中使用 React 组件的库,同时也支持在 React 应用中使用 Vue 组件。它提供了一种方便的方式,使开发人员能够在不同的框架之间无缝地使用对方的组件。

要在 Vue 应用中使用React组件,可以按照以下步骤使用Vuera。

安装插件

安装Vuera:使用npm或yarn在您的Vue项目中安装Vuera库。

// 使用 yarn 安装
yarn add vuera

// 使用 npm 安装
npm i -S vuera

安装依赖。

由于需要在Vue中使用React组件,所以首先需要在项目中安装 React,安装指令如下:

npm install --save react react-dom

项目配置

在babel.config.js文件中添加以下配置即可:

{
  "presets": [
    "react"
  ],
  "plugins": [
    "vuera/babel"
  ]
}

接下来在项目中以插件的形式来引入并使用vuera库,可以在 mAIn.js 中加入如下代码:

import { VuePlugin } from 'vuera'
Vue.use(VuePlugin)

基本使用

完成上述配置之后,就可以在Vue项目中引入并使用React组件了。

React组件代码如下:

import React from 'react'

function myReactComponent(props) {
  const { message } = props
  function childClickHandle() {
    props.onMyEvent('React子组件传递的数据')
  }
  return (
    <div>
      <h2>{ message }</h2>
      <button onClick={ childClickHandle }>向Vue项目传递React子组件的数据</button>
    </div>
  )
}

export default myReactComponent

Vue组件代码如下:

<template>
    <div>
        <h1>I'm a Vue component</h1>
        <my-react-component :message="message" @onMyEvent="parentClickHandle"/>
    </div>
</template>

<script>
    // 引入React组件
    import MyReactComponent from './myReactComponent'

    export default {
        components: {
            'my-react-component': MyReactComponent  // 引入React组件
        },
        data() {
            return {
                message: 'Hello from React!',
            }
        },
        methods: {
            parentClickHandle(data){
                console.log(data);
            }
        },
    }
</script>

在 Vue 项目中引入了这个 React 组件,效果如下:

可以看到,这里实现了Vue到React组件的传值,并显示在了页面上。根据右上角的Chrome插件显示,这个项目中既使用了Vue又使用了React。

点击页面中的按钮,可以看到,数据从React子组件传递到了Vue中:

这样就简单实现了React和Vue组件之间的数据通信。

其他使用方式

如果不想通过 Babel plugin 的方式引入的话,可以使用以下这两种方法。

(1)使用wrApper组件

<template>
  <div>
    <react :component="component" :message="message" />
  </div>
</template>
 
<script>
  import { ReactWrapper } from 'vuera'  // 引入vuera库
  import MyReactComponent from './MyReactComponent'  // 引入react组件
 
  export default {
    data () {
      component: MyReactComponent,
      message: 'Hello from React!',
    },
    components: { react: ReactWrapper }
  }
</script>

(2)使用高阶组件的API

<template>
  <div>
    <my-react-component :message="message" />
  </div>
</template>
 
<script>
  import { ReactWrapper } from 'vuera'  // 引入vuera库
  import MyReactComponent from './MyReactComponent'  // 引入react组件
 
  export default {
    data () {
      message: 'Hello from React!',
    },
    components: { 'my-react-component': ReactInVue(MyReactComponent) }
  }
</script>

在 React 项目中使用 Vue 组件也是同理,可以参考官方文档。

注意

Vuera 是一个比较成熟的 JAVAScrip 库,但是目前已经不再维护(最近一次更新是三年前)。并且,该库不支持 Vue 3,如果想要支持 Vue 3,可以使用 Vueury。

Github:https://github.com/akxcv/vuera。

#vuereact-combined

vuereact-combined 是一个用于 Vue和React快捷集成的工具包,并且适合复杂的集成场景。通过这个工具,可以在任何的Vue和React项目中使用另一个类型框架的组件,并且解决了复杂的集成问题。

vuera 开辟了Vue和React融合的想法,但是 vuera只能解决非常基础的组件融合,并且存在插槽(children)和数据变更后的渲染性能问题,因此无法用于复杂的场景以及生产环境。

vuereact-combined 将融合做到了极致,支持了大部分的Vue和React组件的功能,并且在渲染更新上使用了和vuera不同的思路,完美解决了渲染性能问题

注意,该项目只支持使用 Vue 2,如果想要使用 Vue 3,可以使用上面的介绍的 Veaury。

使用vuereact-combined的步骤如下。

#安装插件

在项目中安装vuereact-combined:

npm install --save vuereact-combined

项目配置

在Vue和React的入口文件中引入 vuereact-combined:

import Vue from 'vue';  
import React from 'react';  
import {Combined} from 'vuereact-combined';  
  
Vue.use(Combined);

配置Babel以支持JSX语法和Vue.js的特性。安装babel-plugin-transform-vue-jsx和babel-preset-react,并在.babelrc文件中添加相应的配置:

{  
  "presets": ["react-app"],  
  "plugins": ["@vue/babel-plugin-transform-vue-jsx"]  
}

在webpack配置文件中添加相应的loader和plugin:

const VueLoaderPlugin = require('vue-loader/lib/plugin');  
module.exports = function(webpackEnv) {  
  module: {  
    rules: [  
      {  
        test: /.vue$/,  
        loader: 'vue-loader',  
      },  
      {  
        test: /.js$/,  
        exclude: /node_modules/(?!(vue|@vue/.*)/).*/,  
        use: {  
          loader: 'babel-loader',  
          options: {  
            presets: ['@babel/preset-env'],  
            plugins: ['@babel/plugin-transform-vue-jsx']  
          }  
        }  
      },  
      // 其他规则...  
    ],  
  },  
  plugins: [  
    new VueLoaderPlugin(),  
    // 其他插件...  
  ],  
};

配置完毕后,就可以在Vue和React之间进行快捷的集成了。

基本使用

假设有一个React组件,它是一个简单的函数组件:

// 来自React项目的组件
const MyReactComponent = () => {
  return <div>Hello React!</div>;
};

可以在Vue项目中引入并使用这个组件。下面是一个使用vuereact-combined的Vue文件示例:

<template>
  <div>
    <MyReactComponent />
  </div>
</template>

<script>
import {Combined} from 'vuereact-combined';
import MyReactComponent from './MyReactComponent'; // 引入React组件

export default {
  components: {
    Combined,
    MyReactComponent // 将React组件注册为Vue组件
  },
  // 其他Vue代码...
};
</script>

这里,首先引入了MyReactComponent,然后在Vue组件中使用它。通过将React组件注册为Vue组件,我们可以在Vue模板中使用它,就像使用普通的Vue组件一样。

这里只展示了最基本的使用方法,其他使用场景可以参考官方文档。

注意事项

  • 在Vue项目中使用第三方的React组件:第三方的react组件已经是通过babel进行过处理,不包含 React 的 jsx。此情况下,可以直接在项目中使用applyReactInVue对第三方的 React 组件进行处理。
  • 在React项目中使用第三方的Vue组件:第三方的Vue组件已经是通过vue-loader和babel进行过处理,不包含.vue文件以及Vue的jsx。此情况下,可以直接在项目中使用applyVueInReact对第三方的Vue组件进行处理。

在 React 项目中引入Vue组件的支持程度:

在 Vue 项目中引入 React 组件:

Github:https://github.com/devilwjp/vuereact-combined。



Tags:Vue   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除。
▌相关推荐
React和Vue是前端开发中的两大热门框架,各自都有着强大的功能和丰富的生态系统。然而,你有没有想过,在一个项目中同时使用React和Vue?是的,你没有听错,可以在同一个项目中混用这两...【详细内容】
2023-09-14  Tags: Vue  点击:(0)  评论:(0)  加入收藏
什么是Vue?Vue[1] 是一个用于构建用户界面的渐进式、可逐步采用的 JavaScript 框架。它由 Evan You[2] 于 2014 年创建,并由一个活跃的开发者社区负责维护。Vue 设计得非常轻...【详细内容】
2023-09-11  Tags: Vue  点击:(5)  评论:(0)  加入收藏
前言本文是笔者写组件设计的第七篇文章, 今天带大家实现一个自带主题且可关闭的Alert组件, 该组件在诸如Antd或者elementUI等第三方组件库中都会出现,主要用来提供系统的用...【详细内容】
2023-09-05  Tags: Vue  点击:(11)  评论:(0)  加入收藏
Vite的快速热更新能力和Vue 3的高效性能,加速了开发周期,使得开发者能够更快地迭代和测试应用。很多vue3的UI可以使用,例如本文选用的arco-design,这就是站在巨人肩膀之上。背景...【详细内容】
2023-08-28  Tags: Vue  点击:(36)  评论:(0)  加入收藏
构建现代大规模应用程序最具挑战性的方面之一是数据获取。加载和错误状态、分页、过滤、排序、缓存等许多功能可能会增加复杂性,并经常使应用程序充满大量的样板代码。这就是...【详细内容】
2023-08-22  Tags: Vue  点击:(13)  评论:(0)  加入收藏
在前端开发中,Vue 一直以其简单、高效的框架而备受开发者青睐。然而,随着 React 在市场上的流行,许多开发者开始对 JSX(JavaScript XML)这种声明式编程风格产生兴趣。本文将探讨...【详细内容】
2023-08-16  Tags: Vue  点击:(19)  评论:(0)  加入收藏
引言有这么一个需求:列表页进入详情页后,切换回列表页,需要对列表页进行缓存,如果从首页进入列表页,就要重新加载列表页。对于这个需求,我的第一个想法就是使用keep-alive来缓存列...【详细内容】
2023-08-15  Tags: Vue  点击:(13)  评论:(0)  加入收藏
最近,因为项目需要,不得不学习一下 vue3。于是花了 4 个小时,把 Vue3 过了一遍。现在我来带你快速了解 Vue3 的写法。本文的目的,是为了让已经有 Vue2 开发经验的 人 ,快速掌握 V...【详细内容】
2023-08-11  Tags: Vue  点击:(5)  评论:(0)  加入收藏
AICube 开放GPT-4给大家使用以及AI工具助手,可以简化大家生图的的prompt在编程中,有两个极具挑战性的任务:缓存失效和命名事物。今天,我们将深入探讨后者,探索为Vue组件命名props...【详细内容】
2023-08-07  Tags: Vue  点击:(22)  评论:(0)  加入收藏
虽然事件总线最初似乎是组件间通信的便捷方法,但建议探索替代选项,例如provide/inject或全局状态管理。这些替代方案为促进组件之间的通信提供了更强大且可维护的解决方案。在...【详细内容】
2023-07-28  Tags: Vue  点击:(41)  评论:(0)  加入收藏
▌简易百科推荐
React和Vue是前端开发中的两大热门框架,各自都有着强大的功能和丰富的生态系统。然而,你有没有想过,在一个项目中同时使用React和Vue?是的,你没有听错,可以在同一个项目中混用这两...【详细内容】
2023-09-14  前端充电宝  微信公众号  Tags:Vue   点击:(0)  评论:(0)  加入收藏
有时候不希望用户去调试或复制前端代码,那该如何禁止用户调试前端代码呢?今天就来分享一个开源的前端工具:Disable Devtool,一行代码禁用 Web 开发者工具!功能简介disable-devtoo...【详细内容】
2023-09-12  前端充电宝  微信公众号  Tags:代码   点击:(4)  评论:(0)  加入收藏
本文来分享一些热门的、经过验证的高颜值移动端UI组件库,帮助你选择适合自己项目的组件库!VantVant 是有赞团队开源的一个轻量、可定制的移动端组件库,于 2017 年开源。目前 Va...【详细内容】
2023-09-11  前端充电宝  微信公众号  Tags:UI组件库   点击:(2)  评论:(0)  加入收藏
什么是Vue?Vue[1] 是一个用于构建用户界面的渐进式、可逐步采用的 JavaScript 框架。它由 Evan You[2] 于 2014 年创建,并由一个活跃的开发者社区负责维护。Vue 设计得非常轻...【详细内容】
2023-09-11  前端F2E  微信公众号  Tags:Vue   点击:(5)  评论:(0)  加入收藏
说起模块化开发大家想必都不陌生,特别是随着前端应用复杂化,代码呈倍数增长,我们不得不耗费大量的时间去进行管理,模块化也就逐渐的被大家所接受。所以具体来讲的话,模块化开发就...【详细内容】
2023-09-06  Onegun    Tags:模块   点击:(14)  评论:(0)  加入收藏
迭代器和生成器是 ES6 中引入的特性。迭代器通过一次消费一个项目列表来提高效率,类似于数据流。生成器是一种能够暂停执行的特殊函数。调用生成器允许以块的形式(一次一个)生...【详细内容】
2023-09-02  前端充电宝  微信公众号  Tags:前端   点击:(4)  评论:(0)  加入收藏
在这篇文章中,我将介绍如何在 Node.js 中使用模块,重点是如何导出和消费它们。各种模块格式由于 JavaScript 最初没有模块的概念,因此随着时间的推移,出现了各种相互竞争的格式...【详细内容】
2023-08-28   前端F2E    Tags:module   点击:(4)  评论:(0)  加入收藏
一、JS库JS库(JavaScript Library)是一组封装了常用功能和工具的JavaScript代码集合。它们提供了一系列的函数和方法,使得开发者能够更便捷地进行常见的操作和处理。JS库通常是...【详细内容】
2023-08-27  贝格前端工场    Tags:js库   点击:(30)  评论:(0)  加入收藏
值得一提的是,本篇文章是对 ROBIN WIERUCH 发表的《 10 Web Development Trends in 2023 》的文章的翻译,但是对部分内容进行了补充和修改,不喜勿喷。关于文章内部提到的诸多...【详细内容】
2023-08-25  高级前端进阶  今日头条  Tags:前端   点击:(31)  评论:(0)  加入收藏
SSE(Server-Send Events)SSE 是一种在基于浏览器的 Web 应用程序中仅从服务器向客户端发送文本消息的技术。SSE基于 HTTP 协议中的持久连接, 具有由 W3C 标准化的网络协议和 Ev...【详细内容】
2023-08-24  碧树西风    Tags:前端   点击:(16)  评论:(0)  加入收藏
站内最新
站内热门
站内头条