Home

Awesome

<h1 align="center">vite-plugin-vue-preview</h1> <p align="center"> <a href="https://github.com/liting-yes/vite-plugin-vue-preview"><img src="https://img.shields.io/github/stars/liting-yes/vite-plugin-vue-preview" alt="Downloads"></a> <a href="https://www.npmjs.com/package/vite-plugin-vue-preview"><img src="https://img.shields.io/npm/dm/vite-plugin-vue-preview" alt="Downloads"></a> <a href="https://www.npmjs.com/package/vite-plugin-vue-preview"><img src="https://img.shields.io/npm/v/vite-plugin-vue-preview" alt="Version"></a> <a href="https://www.npmjs.com/package/vite-plugin-vue-preview"><img src="https://img.shields.io/npm/l/vite-plugin-vue-preview" alt="License"></a> </p> <p align="center"> <a href="./README.zh-CN.md">简体中文</a> </p>

a vite plugin for code preview of vue component in markdown, of course, a VuePreview component is also exported for direct use in vue app.

Demo

<p align="center"> <img src="./public/demo.gif" /> </p>

Install

pnpm add vite-plugin-vue-preview

Features

Props

VuePreview

interface Props {
  // Initialization code string
  code: string
  // Whether to collapse the code when the component is mounted
  collapse: boolean
  // Whether to turn on ssr
  ssr: boolean
  // Background color of preview part
  outputBgColor: string
  // Preview the horizontal layout of the component instance in the container
  justify: 'start' | 'center' | 'end'
  // Previewing the vertical layout of the component instance in the container
  align: 'start' | 'center' | 'end'
}

Usage

Vue

Import the VuePreview component and style

import { createApp } from 'vue'
import { VuePreview } from 'vite-plugin-vue-preview'
import 'vite-plugin-vue-preview/dist/style.css'

const app = createApp({})

app.component('VuePreview', VuePreview)

Vitepress

Import the VuePreview component / style and plugin

// vite.config.ts
import { defineConfig } from 'vite'
import { VuePreviewPlugin } from 'vite-plugin-vue-preview'


export default defineConfig({
  plugins: [VuePreviewPlugin()],
})

// .vitepress/theme/index.ts
import DefaultTheme from 'vitepress/theme'
import { VuePreview } from 'vite-plugin-vue-preview'
import 'vite-plugin-vue-preview/dist/style.css'

export default {
  ...DefaultTheme,
  enhanceApp(ctx) {
    DefaultTheme.enhanceApp(ctx)
    ctx.app.component('VuePreview', VuePreview)
  },
}

Once you've set up the above, you're ready to use it in your markdown file:

<pre> <code> &#96;&#96;&#96;vue preview &lt;template&gt; &lt;div&gt;Demo: vite-plugin-vue-preview&lt;/div&gt; &lt;/template&gt; &#96;&#96;&#96; </code> </pre>

Statement