init
This commit is contained in:
commit
f438d49f55
9
.gitignore
vendored
Normal file
9
.gitignore
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
node_modules
|
||||
*.log*
|
||||
.nuxt
|
||||
.nitro
|
||||
.cache
|
||||
.output
|
||||
.data
|
||||
.env
|
||||
dist
|
22
README.md
Normal file
22
README.md
Normal file
@ -0,0 +1,22 @@
|
||||
# MFE nuxt x nuxt
|
||||
|
||||
MFE with Nuxt being the Host and Remote
|
||||
|
||||
```
|
||||
cd host
|
||||
pnpm i
|
||||
pnpm generate
|
||||
pnpm serve
|
||||
```
|
||||
|
||||
```
|
||||
cd remote
|
||||
pnpm i
|
||||
pnpm generate
|
||||
pnpm serve
|
||||
```
|
||||
|
||||
# TODO
|
||||
|
||||
- Enable CORS on remote JS assets
|
||||
- Scoped style still not works
|
23
host/app.vue
Normal file
23
host/app.vue
Normal file
@ -0,0 +1,23 @@
|
||||
<template>
|
||||
<div class="container mx-auto p-4">
|
||||
<h1 class="text-2xl font-bold mb-4">Nuxt 3 MFE Host App</h1>
|
||||
<div class="grid grid-cols-1 gap-4">
|
||||
<HostComponent />
|
||||
<Suspense>
|
||||
<template #default>
|
||||
<RemoteComponent />
|
||||
</template>
|
||||
<template #fallback>
|
||||
<div>Loading remote component...</div>
|
||||
</template>
|
||||
</Suspense>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
import { defineAsyncComponent } from 'vue'
|
||||
import HostComponent from './components/HostComponent.vue'
|
||||
|
||||
const RemoteComponent = defineAsyncComponent(() => import('remote/RemoteComponent'))
|
||||
</script>
|
12
host/components/HostComponent.vue
Normal file
12
host/components/HostComponent.vue
Normal file
@ -0,0 +1,12 @@
|
||||
<template>
|
||||
<div class="p-4 border rounded">
|
||||
<h2 class="text-xl mb-2">Host Component</h2>
|
||||
<p>This is a component from the host application</p>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
defineComponent({
|
||||
name: 'HostComponent'
|
||||
})
|
||||
</script>
|
22
host/nuxt.config.ts
Normal file
22
host/nuxt.config.ts
Normal file
@ -0,0 +1,22 @@
|
||||
import { defineNuxtConfig } from 'nuxt/config'
|
||||
import federation from '@originjs/vite-plugin-federation'
|
||||
|
||||
export default defineNuxtConfig({
|
||||
compatibilityDate: '2024-04-03',
|
||||
devtools: { enabled: false },
|
||||
ssr: false,
|
||||
vite: {
|
||||
plugins: [
|
||||
federation({
|
||||
name: 'host-app',
|
||||
remotes: {
|
||||
remote: 'http://localhost:3001/_nuxt/remoteEntry.js',
|
||||
},
|
||||
// shared: ['vue']
|
||||
})
|
||||
],
|
||||
build: {
|
||||
target: 'esnext'
|
||||
}
|
||||
}
|
||||
})
|
24
host/package.json
Normal file
24
host/package.json
Normal file
@ -0,0 +1,24 @@
|
||||
{
|
||||
"name": "nuxt-mfe-host",
|
||||
"private": true,
|
||||
"type": "module",
|
||||
"scripts": {
|
||||
"build": "nuxt build",
|
||||
"dev": " nuxt dev",
|
||||
"pregenerate": "npm run clean",
|
||||
"generate": "nuxt generate",
|
||||
"preview": "nuxt preview",
|
||||
"postinstall": "nuxt prepare",
|
||||
"clean": "rimraf .output",
|
||||
"serve": "serve .output/public -p 3000"
|
||||
},
|
||||
"dependencies": {
|
||||
"nuxt": "^3.13.0",
|
||||
"vue": "^3.5.13"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@originjs/vite-plugin-federation": "^1.3.5",
|
||||
"rimraf": "6",
|
||||
"serve": "*"
|
||||
}
|
||||
}
|
6797
host/pnpm-lock.yaml
Normal file
6797
host/pnpm-lock.yaml
Normal file
File diff suppressed because it is too large
Load Diff
BIN
host/public/favicon.ico
Normal file
BIN
host/public/favicon.ico
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.2 KiB |
1
host/public/robots.txt
Normal file
1
host/public/robots.txt
Normal file
@ -0,0 +1 @@
|
||||
|
4
host/tsconfig.json
Normal file
4
host/tsconfig.json
Normal file
@ -0,0 +1,4 @@
|
||||
{
|
||||
// https://v3.nuxtjs.org/concepts/typescript
|
||||
"extends": "./.nuxt/tsconfig.json"
|
||||
}
|
6
remote/app.vue
Normal file
6
remote/app.vue
Normal file
@ -0,0 +1,6 @@
|
||||
<template>
|
||||
<div class="container mx-auto p-4">
|
||||
<h1 class="text-2xl font-bold mb-4">Nuxt 3 MFE Remote App</h1>
|
||||
<RemoteComponent />
|
||||
</div>
|
||||
</template>
|
22
remote/components/RemoteComponent.vue
Normal file
22
remote/components/RemoteComponent.vue
Normal file
@ -0,0 +1,22 @@
|
||||
<template>
|
||||
<div class="p-4 border rounded bg-blue-50 sty1">
|
||||
<h2 class="text-xl mb-2">Remote Component</h2>
|
||||
<p>This component is exposed from the remote application</p>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
defineComponent({
|
||||
name: 'RemoteComponent'
|
||||
})
|
||||
|
||||
onMounted(() => {
|
||||
console.log('mounted')
|
||||
})
|
||||
</script>
|
||||
|
||||
<style>
|
||||
.sty1 {
|
||||
background: pink;
|
||||
}
|
||||
</style>
|
24
remote/nuxt.config.ts
Normal file
24
remote/nuxt.config.ts
Normal file
@ -0,0 +1,24 @@
|
||||
import { defineNuxtConfig } from 'nuxt/config'
|
||||
import federation from '@originjs/vite-plugin-federation'
|
||||
|
||||
export default defineNuxtConfig({
|
||||
compatibilityDate: '2024-04-03',
|
||||
devtools: { enabled: false },
|
||||
ssr: false,
|
||||
vite: {
|
||||
plugins: [
|
||||
federation({
|
||||
name: 'remote-app',
|
||||
filename: 'remoteEntry.js',
|
||||
exposes: {
|
||||
'./RemoteComponent': './components/RemoteComponent.vue'
|
||||
},
|
||||
shared: []
|
||||
// shared: ['vue']
|
||||
})
|
||||
],
|
||||
build: {
|
||||
target: 'esnext'
|
||||
}
|
||||
}
|
||||
})
|
24
remote/package.json
Normal file
24
remote/package.json
Normal file
@ -0,0 +1,24 @@
|
||||
{
|
||||
"name": "nuxt-mfe-remote",
|
||||
"private": true,
|
||||
"type": "module",
|
||||
"scripts": {
|
||||
"build": "nuxt build",
|
||||
"dev": "HOST=0.0.0.0 PORT=3001 nuxt dev",
|
||||
"pregenerate": "npm run clean",
|
||||
"generate": "nuxt generate",
|
||||
"preview": "nuxt preview",
|
||||
"postinstall": "nuxt prepare",
|
||||
"clean": "rimraf .output",
|
||||
"serve": "serve .output/public -p 3001"
|
||||
},
|
||||
"dependencies": {
|
||||
"nuxt": "^3.13.0",
|
||||
"vue": "^3.5.13"
|
||||
},
|
||||
"devDependencies": {
|
||||
"serve": "*",
|
||||
"rimraf": "6",
|
||||
"@originjs/vite-plugin-federation": "^1.3.5"
|
||||
}
|
||||
}
|
6797
remote/pnpm-lock.yaml
Normal file
6797
remote/pnpm-lock.yaml
Normal file
File diff suppressed because it is too large
Load Diff
BIN
remote/public/favicon.ico
Normal file
BIN
remote/public/favicon.ico
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.2 KiB |
1
remote/public/robots.txt
Normal file
1
remote/public/robots.txt
Normal file
@ -0,0 +1 @@
|
||||
|
4
remote/tsconfig.json
Normal file
4
remote/tsconfig.json
Normal file
@ -0,0 +1,4 @@
|
||||
{
|
||||
// https://v3.nuxtjs.org/concepts/typescript
|
||||
"extends": "./.nuxt/tsconfig.json"
|
||||
}
|
Loading…
Reference in New Issue
Block a user