欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vite創(chuàng)建一個(gè)標(biāo)準(zhǔn)vue3+ts+pinia項(xiàng)目

 更新時(shí)間:2022年05月18日 14:17:58   作者:xfan0516  
本文主要介紹了vite創(chuàng)建一個(gè)標(biāo)準(zhǔn)vue3+ts+pinia項(xiàng)目,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

使用vite創(chuàng)建一個(gè)標(biāo)準(zhǔn)vue3+ts+pinia項(xiàng)目的實(shí)現(xiàn)示例

【01】使用的 Yarn創(chuàng)建項(xiàng)目:

1、執(zhí)行命令

yarn create vite my-vue-app --template vue-ts

3、cd my-vue-app //進(jìn)入到項(xiàng)目
4、yarn // 安裝依賴
5、yarn dev // 運(yùn)行項(xiàng)目

vite.config.ts

import path from 'path' // 需要安裝 @types/node 并在 tsconfig.node.json的compilerOptions中配置"allowSyntheticDefaultImports": true
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
function _resolve(dir) {
? return path.resolve(__dirname, dir);
}
// https://vitejs.dev/config/
export default defineConfig({
? plugins: [vue()],
? server:{
? ? host: '0.0.0.0', // 監(jiān)聽本地所有ip
? ? port: 3010 // 項(xiàng)目端口
? },
? resolve:{
? ? alias:{
? ? ? '@': _resolve('src') // 別名
? ? }
? }
})

【02】在項(xiàng)目中使用pinia

pinia官網(wǎng)

1. 安裝pinia

yarn add pinia

2. 引用到項(xiàng)目

import { createApp } from 'vue'
import App from './App.vue'
import { createPinia } from 'pinia' // 導(dǎo)入pinia

const app = createApp(App)
app.use(createPinia()) // 注冊(cè)pinia

app.mount('#app')

3. 使用pinia Demo

// ./src/stores/counterStore.ts

import { defineStore } from 'pinia',

const useCounterStore = defineStore('counterStore', {
? state: () => ({
? ? counter: 0
? })
})

?
// setup中使用

import { useCounterStore } from '../stores/counterStore'

export default {
? setup() {
? ? const counterStore = useCounterStore()

? ? return { counterStore }
? },
? computed: {
? ? tripleCounter() {
? ? ? return counterStore.counter * 3
? ? },
? },
}

【03】添加vue-router

1. 安裝 router

yarn add vue-router

2. 如何使用

1). 創(chuàng)建router

// src/router/index.ts
import { createRouter, createWebHashHistory, RouteRecordRaw } from "vue-router";

const routes: RouteRecordRaw[] = [
? {
? ? path: '/login', // 瀏覽器訪問地址
? ? name: 'Login',
? ? component: () => import(/* webpackChunkName: "login"*/ new URL('../pages/Login/index.vue', import.meta.url).href ),
? ? mate:{}
? }
]

const router = createRouter({
? history: createWebHashHistory(),
? routes,
})

export default router

2). 引用到項(xiàng)目

// main.ts
import router from './router'

app.use(router)

【04】 安裝按需自動(dòng)導(dǎo)入插件

1. 首先需要安裝unplugin-auto-import和unplugin-vue-components兩個(gè)插件

- unplugin-auto-import: 自動(dòng)導(dǎo)入api [github鏈接](https://github.com/antfu/unplugin-auto-import)
- unplugin-vue-components: 自動(dòng)導(dǎo)入使用的組件 [github鏈接](https://github.com/antfu/unplugin-vue-components)

yarn add unplugin-auto-import unplugin-vue-components -D

2. 配置 vite.cinfig.ts

import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'

export default defineConfig({
? plugins: [
? ? // 自動(dòng)導(dǎo)入API方法
? ? AutoImport({
? ? ? imports: [ ?// 自動(dòng)導(dǎo)入API配置
? ? ? ? 'vue',?
? ? ? ? 'vue-router',
? ? ? ? 'pinia',
? ? ? ],
? ? ? resolvers: [], // custom resolvers
? ? ? dts: 'src/typings/auto-imports.d.ts', // 導(dǎo)入存放地址
? ? }),
? ? // 自動(dòng)導(dǎo)入組件
? ? Components({
? ? ? resolvers: [], // custom resolvers
? ? ? dts: 'src/typings/components.d.ts',
? ? }),
? ]
})

【05】 添加element-plus組件庫

1. 先安裝依賴包

yarn add element-plus

2. 自動(dòng)導(dǎo)入樣式和組件

1). 首先你需要安裝unplugin-vue-components 和 unplugin-auto-import這兩款插件

yarn add unplugin-vue-components unplugin-auto-import -D

2). 配置到vite

// vite.config.ts

import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'

export default defineConfig({
? plugins: [
? ? // 自動(dòng)導(dǎo)入 Element Plus 相關(guān)函數(shù),如:ElMessage, ElMessageBox... (帶樣式)
? ? AutoImport({
? ? ? resolvers: [ElementPlusResolver()],
? ? }),
? ? // 自動(dòng)導(dǎo)入 Element Plus 組件
? ? Components({
? ? ? resolvers: [ElementPlusResolver()],
? ? }),
? ],
})

3. element-plus 圖標(biāo)庫

1). 安裝依賴包

// 安裝包    
yarn add @element-plus/icons-vue

2). 自動(dòng)導(dǎo)入icon組件配置

// 使用unplugin-icons和unplugin-auto-import自動(dòng)從Iconify導(dǎo)入任何圖標(biāo)集合
yarn add unplugin-auto-import unplugin-icons -D
// vite.config.ts

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
// 自動(dòng)導(dǎo)入element圖標(biāo)
import Icons from 'unplugin-icons/vite'
import IconsResolver from 'unplugin-icons/resolver'
import Inspect from 'vite-plugin-inspect'
const path = require('path');
function _resolve(dir) {
? return path.resolve(__dirname, dir);
}
// https://vitejs.dev/config/
export default defineConfig({
? plugins: [
? ? vue(),
? ? // 自動(dòng)導(dǎo)入 Element Plus 相關(guān)函數(shù),如:ElMessage, ElMessageBox... (帶樣式)
? ? AutoImport({
? ? ? resolvers: [
? ? ? ? ElementPlusResolver(),
? ? ? ? // 自動(dòng)導(dǎo)入圖標(biāo)組件
? ? ? ? IconsResolver({
? ? ? ? ? prefix: 'Icon',
? ? ? ? }),
? ? ? ??
? ? ? ],
? ? ? dts: path.resolve(_resolve('src'), 'auto-imports.d.ts'),
? ? }),
? ? // 自動(dòng)導(dǎo)入 Element Plus 組件
? ? Components({
? ? ? resolvers: [
? ? ? ? // 自動(dòng)注冊(cè)圖標(biāo)組件
? ? ? ? IconsResolver({
? ? ? ? ? enabledCollections: ['ep'],
? ? ? ? }),
? ? ? ? ElementPlusResolver()],
? ? }),
? ? Icons({
? ? ? autoInstall: true, // 是否自動(dòng)加載
? ? }),
? ? Inspect(),
? ],
? server:{
? ? host: '0.0.0.0', // 監(jiān)聽本地所有ip
? ? port: 3010 // 項(xiàng)目端口
? },
? resolve:{
? ? alias:{
? ? ? '@': _resolve('src') // 別名
? ? }
? }
})

3). 使用方法

<template>
    <i-ep-add-location />
    <IEpRefresh />
</template>

【06】添加sass

1. 安裝

yarn add sass sass-loader -D

2. 配置sass全局變量

// vite.config.ts
export default {
  css:{
    preprocessorOptions: {
      scss: {
        additionalData: "@import './src/assets/css/mixin.scss';",
      },
    },
  }
}

【07】 安裝prettier 和 eslint

1.安裝依賴項(xiàng)

// 安裝prettier------------------------------------------------------------
yarn add prettier eslint-config-prettier eslint-plugin-prettier -D

// 安裝eslint-------------------------------------------------
yarn add eslint eslint-plugin-vue eslint-config-airbnb-base eslint-plugin-import @typescript-eslint/eslint-plugin @typescript-eslint/parser -D

2.根目錄添加.prettierrc.js文件

// .prettierrc.js

exports.modules = {
? // 設(shè)置強(qiáng)制單引號(hào)
? singleQuote: true,
? autoFix: false,
? printWidth: 140,
? semi: false,
? trailingComma: "none",
? arrowParens: "avoid",
? endOfLine: "LF",
};

3. 根目錄添加.eslintrc.js文件

eslint官網(wǎng)

// .eslintrc.js

module.exports = {
? env: {
? ? browser: true,
? ? es2021: true,
? },
? extends: [
? ? "plugin:vue/vue3-essential",
? ? "airbnb-base",
? ? "@vue/typescript/recommended",
? ? "@vue/prettier",
? ? "@vue/prettier/@typescript-eslint",
? ],
? parserOptions: {
? ? ecmaVersion: "latest",
? ? parser: "@typescript-eslint/parser",
? ? sourceType: "module",
? },
? plugins: ["vue", "@typescript-eslint"],
? rules: {
? ? "vue/no-multiple-template-root": "off", // 關(guān)閉多根節(jié)點(diǎn)的校驗(yàn)vue3可使用多個(gè)根節(jié)點(diǎn)
? ? quotes: ["error", "single"], // 引號(hào)規(guī)則為:“單引號(hào)”,否則一律按照 “error” 處理(你也可以改成warn試一下)
? },
};

到此這篇關(guān)于vite創(chuàng)建一個(gè)標(biāo)準(zhǔn)vue3+ts+pinia項(xiàng)目的文章就介紹到這了,更多相關(guān)vite創(chuàng)建vue3+ts+pinia內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Element-Plus之el-col與el-row快速布局

    Element-Plus之el-col與el-row快速布局

    el-col是el-row的子元素,下面這篇文章主要給大家介紹了關(guān)于Element-Plus之el-col與el-row快速布局的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • vue獲取el-form的整體驗(yàn)證狀態(tài)

    vue獲取el-form的整體驗(yàn)證狀態(tài)

    本文主要介紹了vue獲取el-form的整體驗(yàn)證狀態(tài),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • VUE Error: getaddrinfo ENOTFOUND localhost

    VUE Error: getaddrinfo ENOTFOUND localhost

    這篇文章主要介紹了VUE Error: getaddrinfo ENOTFOUND localhost,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05
  • Vue項(xiàng)目三級(jí)聯(lián)動(dòng)路由跳轉(zhuǎn)與傳參的思路詳解

    Vue項(xiàng)目三級(jí)聯(lián)動(dòng)路由跳轉(zhuǎn)與傳參的思路詳解

    這篇文章主要介紹了Vue項(xiàng)目三級(jí)聯(lián)動(dòng)的路由跳轉(zhuǎn)與傳參的思路詳解,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • vue中使用sessionStorage記住密碼功能

    vue中使用sessionStorage記住密碼功能

    sessionStorage不是一種持久化的本地存儲(chǔ),僅僅是會(huì)話級(jí)別的存儲(chǔ)。這篇文章主要介紹了vue中使用sessionStorage記住密碼功能,需要的朋友可以參考下
    2018-07-07
  • 解決vue一個(gè)頁面中復(fù)用同一個(gè)echarts組件的問題

    解決vue一個(gè)頁面中復(fù)用同一個(gè)echarts組件的問題

    這篇文章主要介紹了解決vue一個(gè)頁面中復(fù)用同一個(gè)echarts組件的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • 前端vue3樹形組件使用代碼示例

    前端vue3樹形組件使用代碼示例

    最近在開發(fā)時(shí)遇到一個(gè)問題,是在輸入框里面放一個(gè)樹形組件,這篇文章主要給大家介紹了關(guān)于前端vue3樹形組件使用的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-07-07
  • 如何寫好一個(gè)vue組件,老夫的一年經(jīng)驗(yàn)全在這了(推薦)

    如何寫好一個(gè)vue組件,老夫的一年經(jīng)驗(yàn)全在這了(推薦)

    這篇文章主要介紹了如何寫好一個(gè)vue組件,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • element帶輸入建議el-autocomplete的使用

    element帶輸入建議el-autocomplete的使用

    本文主要介紹了element帶輸入建議el-autocomplete的使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Element通過v-for循環(huán)渲染的form表單校驗(yàn)的實(shí)現(xiàn)

    Element通過v-for循環(huán)渲染的form表單校驗(yàn)的實(shí)現(xiàn)

    日常業(yè)務(wù)開發(fā)中,form表單校驗(yàn)是一個(gè)很常見的問題,本文主要介紹了Element通過v-for循環(huán)渲染的form表單校驗(yàn)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04

最新評(píng)論