Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/ryan-ahn/npm-nuxt3-starter

Nuxt3 프로젝트 시작을 위한 NPM 패키지
https://github.com/ryan-ahn/npm-nuxt3-starter

eslint-rules nuxt3 pinia stylelint-rules typescript vite

Last synced: 4 months ago
JSON representation

Nuxt3 프로젝트 시작을 위한 NPM 패키지

Awesome Lists containing this project

README

        

# Ryan's Nuxt3 Awesome Starter

![Author](https://img.shields.io/badge/Author-ryan-orange.svg)
![License](https://img.shields.io/badge/License-MIT-blue.svg)
![Last Commit](https://img.shields.io/github/last-commit/ryan-ahn/npm-nuxt3-starter)

## Features
- [x] ⚙️  Small & Fast Bundler (Vite)
- [x] 🗝️  Typed Programming (Typescript)
- [x] 🧩  SSR & Page Transition (Nuxt3)
- [x] 📚  Composition API & Setup (Vue3)
- [x] 🕋  Simple Store (Pinia)
- [x] 📙  Use Strict Codebase (ESLint)
- [x] 📘  Use Strict Style (StyleLint)
- [x] 🧵  Built-in Component & Layout
- [x] 🚰  Handle Page to Middleware
- [x] ✨  Setting Reset Style
- [x] ⚡️  Setting Mixin Style
- [x] 📍  Absolute Path
- [x] 📱  Check Device
- [x] 📫  Page SEO
- [ ] 🪄  Dark Mode

## Frameworks
- **Bundler** : Vite
- **SSR** : Nuxt3
- **Core** : Vue3
- **Store** : Pinia

## Code Pattern
- **assets** - static resource

- **components** - atomic stateless components

- **containers** - stateful components

- **pages** - page components(SEO)

- **public** - default public

- **plugins** - plugins

- **interface** - interfaces

- **layouts** - layouts

- **server** - ssr

- **store** - store

- **styles** - style set

- **utils** - hooks, helper, handler

## Getting Started
### 1) Installation
```shell
npx nuxt3-starter my-project
cd my-project
```
### 2) Run Project
```shell
npm run dev
```
### 3) Run Deploy
```shell
npm run build
```

## Using with Vue3 Script Setup
```vue

{{ title }}

// use function
const function = () => {console.log('Hello World!')}
// use props
const props = defineProps({title})

```

## Using with Store
```vue

import { storeToRefs } from 'pinia';
import useDataStore from '@store/useDataStore';
// use store
const store = useDataStore();
// use store state
const { data } = storeToRefs(store);
// use store function
store.getData()

```

## Using with Mixin

```scss
.app {
// flex set(justify-content, align-items, flex-direction)
@include flexSet('center', 'center', 'row')

// box set(width, height, border-radius)
@include boxSet(00px, 00px, 00px)

// color set(color, background-color)
@include colorSet($white, $black)

// background set(url, object-fit)
@include backgroundSet('url', 00px)

// font set(font-size, font-weight, line-height)
@include fontSet(00px, 000, 00px);

// ellipsis set(line, line-height)
@include ellipsisSet(0, 00px)

// shadow set(length, length, blur, color, opacity)
@include shadowSet(0, 0, 0, $white, 0.1)
}
```