Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/vclemenzi/vite-plugin-multip

Create powerful multi-page applications with Vite
https://github.com/vclemenzi/vite-plugin-multip

mpa plugin typescript vite

Last synced: 3 months ago
JSON representation

Create powerful multi-page applications with Vite

Awesome Lists containing this project

README

        

# vite-plugin-multip

[![npm version](https://img.shields.io/npm/v/vite-plugin-multip)](https://npmjs.com/package/vite-plugin-multip)
[![weekly downloads](https://img.shields.io/npm/dw/vite-plugin-multip)](https://npmjs.com/package/vite-plugin-multip)
[![license](https://img.shields.io/npm/l/vite-plugin-multip)](https://github.com/vclemenzi/vite-plugin-multip/blob/main/LICENSE)

The `vite-plugin-multip` plugin enables you to create multi-page applications with Vite!

- 📦 Automatic CSS file importing
- 🧬 Layouts support
- 🔎 Framework recognition
- 📝 Markdown support
- 🥏 Multi-Framework support

# Installation

```bash
npm install vite-plugin-multip
```

_Alternatively, you can use your favorite package manager._

After installing the plugin, proceed with initialization in the `vite.config.ts` file:

```typescript
import { defineConfig } from "vite";
import { svelte } from "@sveltejs/vite-plugin-svelte";
import { multip } from "vite-plugin-multip";

export default defineConfig({
plugins: [
svelte(),
multip(), // Optional configuration parameters can be passed here
],
});
```

> [!NOTE]
> In the above example, the Svelte adapter is used, but the plugin also automatically supports Vue and React.

Now, let's start by creating the appropriate directories:

```bash
src/
pages/
index.(svelte|tsx|vue)
subroute/
index.(svelte|tsx|vue)
```

Remove imports in `index.html` (required):

```diff




Vite + Svelte + TS

+
-


-

```

_index.html works as a layout_

Now, build:

```bash
npm run build
```

> [!NOTE]
> The `dist/` directory can be directly integrated with your backend without modification.

# Configuration

Configuration parameters

```ts
// plugins: [multip(...config)]
type Config = {
directory?: string;
page?: Page;
minify?: import("html-minifier-terser").Options;
assets?: import("rollup-plugin-copy").Target[];
};

type Page = {
title?: string | ((file: string) => string);
};
```

# Framework Support

| Framework | Support |
| --------- | ------- |
| React | Yes |
| Vue | Yes |
| Svelte | Yes |
| Solid | Yes |
| Qwik | No |
| Lit | No |