Rumah > hujung hadapan web > View.js > 使用React、Vue和Single SPA创建微型前端

使用React、Vue和Single SPA创建微型前端

青灯夜游
Lepaskan: 2020-10-28 17:30:15
ke hadapan
2456 orang telah melayarinya

本篇文章给大家介绍一下使用React、Vue和Single SPA创建微型前端的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

使用React、Vue和Single SPA创建微型前端

Single SPA

Single SPA 是一个用于前端微服务的 javascript 框架。

它使你可以在单页应用中使用多个框架,这样就可以按功能拆分代码,并 能使 Angular、React、Vue.js 程序一起运行。

你可能已经习惯了 React 和 Vue 的 CLI,通过这些工具可以快速创建项目,并准备好 webpack 的配置、依赖项和样板代码等。

如果你已经习惯了这种操作,那么你可能会觉得本文的前半部分有些繁琐。因为我们要从头创建所有内容,包括安装所需的所有依赖项以及从零创建 webpack 和 babel 配置。

环境与配置

首先在终端下创建一个新目录并进入其中:

mkdir single-spa-app

cd single-spa-app
Salin selepas log masuk

接下来初始化 package.json 文件:

npm init -y
Salin selepas log masuk

然后安装项目所需的所有依赖项。为了让大家清楚的知道都安装了些什么,在这里我把它们分解成单独的步骤。

安装依赖项

安装常规依赖项

npm install react react-dom single-spa single-spa-react single-spa-vue vue
Salin selepas log masuk

安装 babel 依赖项

npm install @babel/core @babel/plugin-proposal-object-rest-spread @babel/plugin-syntax-dynamic-import @babel/preset-env @babel/preset-react babel-loader --save-dev
Salin selepas log masuk

安装 Webpack 依赖项

npm install webpack webpack-cli webpack-dev-server clean-webpack-plugin css-loader html-loader style-loader vue-loader vue-template-compiler --save-dev
Salin selepas log masuk

在所有依赖项安装完毕后,创建目录结构。

我们把项目代码到 src 目录中。在目录中包含每个程序的子文件夹。继续在 src 目录中创建 reactvue 程序的目录:

mkdir src src/vue src/react
Salin selepas log masuk

下面配置 webpack 和 babel。

环境配置

配置 Webpack

在主程序的根目录中,创建 webpack.config.js 文件并添加一下内容:

const path = require('path');
const webpack = require('webpack');
const { CleanWebpackPlugin } = require('clean-webpack-plugin');
const VueLoaderPlugin = require('vue-loader/lib/plugin')

module.exports = {
  mode: 'development',
  entry: {
    'single-spa.config': './single-spa.config.js',
  },
  output: {
    publicPath: '/dist/',
    filename: '[name].js',
    path: path.resolve(__dirname, 'dist'),
  },
  module: {
    rules: [
      {
        test: /\.css$/,
        use: ['style-loader', 'css-loader']
      }, {
        test: /\.js$/,
        exclude: [path.resolve(__dirname, 'node_modules')],
        loader: 'babel-loader',
      },
      {
        test: /\.vue$/,
        loader: 'vue-loader'
      }
    ],
  },
  node: {
    fs: 'empty'
  },
  resolve: {
    alias: {
      vue: 'vue/dist/vue.js'
    },
    modules: [path.resolve(__dirname, 'node_modules')],
  },
  plugins: [
    new CleanWebpackPlugin(),
    new VueLoaderPlugin()
  ],
  devtool: 'source-map',
  externals: [],
  devServer: {
    historyApiFallback: true
  }
};
Salin selepas log masuk

配置 babel

在根目录中创建 .babelrc 文件并添加以下内容:

{
  "presets": [
    ["@babel/preset-env", {
      "targets": {
        "browsers": ["last 2 versions"]
      }
    }],
    ["@babel/preset-react"]
  ],
  "plugins": [
    "@babel/plugin-syntax-dynamic-import",
    "@babel/plugin-proposal-object-rest-spread"
  ]
}
Salin selepas log masuk

初始化 Single-spa

这一步骤是对你的应用进行注册,用来告诉 single-spa 找到、装载和卸载程序的时机和方法。

webpack.config.js 文件中,把入口设置为 single-spa.config.js

在项目的根目录中创建这个文件并进行配置。

single-spa.config.js

import { registerApplication, start } from 'single-spa'

registerApplication(
  'vue', 
  () => import('./src/vue/vue.app.js'),
  () => location.pathname === "/react" ? false : true
);

registerApplication(
  'react',
  () => import('./src/react/main.app.js'),
  () => location.pathname === "/vue"  ? false : true
);

start();
Salin selepas log masuk

这个文件用来注册用不同框架为主单页应用开发的每个部分。每调用一次 registerApplication 都会注册一个新的应用,它接受三个参数:

  1. 应用的名称
  2. 要加载的函数(要加载的入口点)
  3. 用来激活的函数(用于告知是否加载应用的逻辑)

接下来需要为每个应用创建代码。

React 应用

src/react 目录中创建以下两个文件:

touch main.app.js root.component.js
Salin selepas log masuk

src/react/main.app.js

import React from 'react';
import ReactDOM from 'react-dom';
import singleSpaReact from 'single-spa-react';
import Home from './root.component.js';

function domElementGetter() {
  return document.getElementById("react")
}

const reactLifecycles = singleSpaReact({
  React,
  ReactDOM,
  rootComponent: Home,
  domElementGetter,
})

export const bootstrap = [
  reactLifecycles.bootstrap,
];

export const mount = [
  reactLifecycles.mount,
];

export const unmount = [
  reactLifecycles.unmount,
];
Salin selepas log masuk

src/react/root.component.js

import React from "react"

const App = () => <h1>Hello from React</h1>

export default App
Salin selepas log masuk

Vue 应用

src/vue 目录中创建以下两个文件:

touch vue.app.js main.vue
Salin selepas log masuk

src/vue/vue.app.js

import Vue from 'vue';
import singleSpaVue from 'single-spa-vue';
import Hello from './main.vue'

const vueLifecycles = singleSpaVue({
  Vue,
  appOptions: {
    el: '#vue',
    render: r => r(Hello)
  } 
});

export const bootstrap = [
  vueLifecycles.bootstrap,
];

export const mount = [
  vueLifecycles.mount,
];

export const unmount = [
  vueLifecycles.unmount,
];
Salin selepas log masuk

src/vue/main.vue

<template>
  <p>
      <h1>Hello from Vue</h1>
  </p>
</template>
Salin selepas log masuk

接下来,在程序的根目录中创建 index.html 文件:

touch index.html
Salin selepas log masuk

index.html

<html>
  <body>
    <p id="react"></p>
    <p id="vue"></p>
    <script src="/dist/single-spa.config.js"></script>
  </body>
</html>
Salin selepas log masuk

用脚本更新 Package.json

在 package.json 中添加启动脚本和构建脚本:

"scripts": {
  "start": "webpack-dev-server --open",
  "build": "webpack --config webpack.config.js -p"
}
Salin selepas log masuk

运行程序

通过运行 start 执行程序:

npm start
Salin selepas log masuk

现在可以通过以下URL访问了:

# 渲染基于所有框架的程序
http://localhost:8080/

# 只渲染 react
http://localhost:8080/react

# 之渲染 vue
http://localhost:8080/vue
Salin selepas log masuk

总结

除了开始时的配置外,其他工作都很轻松。如果以后 Single-spa 能够添加处理样板文件和初始项目设置的 CLI 会更好。

如果你需要微前端这种类型的体系结构,那么 Single-spa 无疑是现在最成熟的方法。

原文:https://dev.to/dabit3/building-micro-frontends-with-react-vue-and-single-spa-52op

作者:Nader Dabit

相关推荐:

2020年前端vue面试题大汇总(附答案)

vue教程推荐:2020最新的5个vue.js视频教程精选

更多编程相关知识,请访问:编程入门!!

Atas ialah kandungan terperinci 使用React、Vue和Single SPA创建微型前端. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan