透過超過 100 個技巧學習 Nuxt!

vcalendar
@samk-dev/nuxt-vcalendar

用於 Nuxt 的 VCalendar 模組

Nuxt VCalendar

npm versionnpm downloadsLicenseNuxt

在 Nuxt 中整合 V Calendar

VCalendar 文件

特色

  • 零配置
  • 前綴 VCalendar 元件
  • 自動導入所有 VCalendar 元件或僅導入您需要的元件

快速設定

  1. @samk-dev/nuxt-vcalendar 相依性新增至您的專案
npx nuxi@latest module add @samk-dev/nuxt-vcalendar

就這樣!您現在可以在您的 Nuxt 應用程式中使用 Nuxt VCalendar ✨

手動安裝

  1. 將 @samk-dev/nuxt-vcalendar 相依性新增至您的專案
# Using pnpm
pnpm add -D @samk-dev/nuxt-vcalendar

# Using yarn
yarn add --dev @samk-dev/nuxt-vcalendar

# Using npm
npm install --save-dev @samk-dev/nuxt-vcalendar
  1. @samk-dev/nuxt-vcalendar 新增至 nuxt.config.tsmodules 區段
export default defineNuxtConfig({
  modules: ['@samk-dev/nuxt-vcalendar']
})

Stackblitz 範例

https://stackblitz.com/edit/nuxt-starter-2zwgab?file=app.vue

使用範例

<script setup lang="ts">
  import { ref } from '#imports'
  const date = ref(new Date())

  const attrs = ref([
    {
      key: 'today',
      highlight: {
        color: 'green',
        fillMode: 'solid'
      },
      dates: new Date()
    }
  ])
</script>

<template>
  <div>
    <client-only>
      <h2>Calendar</h2>
      <VCalendar v-model="date" />
      <h2>Date Picker</h2>
      <VDatePicker v-model="date" :attributes="attrs" />
    </client-only>
  </div>
</template>

模組選項

export type VCalendarComponents = {
  DatePicker: boolean
  Calendar: boolean
}
export interface ModuleOptions {
  /**
   * @description prefix instead of v-
   * @default V
   */
  prefix: string
  /**
   * @description load v-calendar styles
   * @default true
   */
  defaultCss: boolean
  /**
   * @description load custom stylesheet
   * @default undefined
   */
  cssPath?: string
  /**
   * @description v-calendar options
   * @see https://vcalendar.io/calendar/api.html#defaults
   */
  calendarOptions?: Defaults
  /**
   * @description auto import v-calendar components
   * @default {DatePicker, true, Calendar: true}
   */
  autoImports: VCalendarComponents
}

開發

# Install dependencies
npm install

# Generate type stubs
npm run dev:prepare

# Develop with the playground
npm run dev

# Build the playground
npm run dev:build

# Run ESLint
npm run lint

# Run Vitest
npm run test
npm run test:watch

# Release new version
npm run release

Alt