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

使用WebStorm開發(fā)Vue3項(xiàng)目詳細(xì)教程

 更新時(shí)間:2024年11月09日 09:15:41   作者:Pannikin  
這篇文章主要介紹了使用WebStorm開發(fā)Vue3項(xiàng)目的相關(guān)資料,本文介紹了在WebStorm中使用Vue3、TypeScript、Sass開發(fā)項(xiàng)目的配置過程,包括版本兼容性問題、項(xiàng)目搭建、依賴包安裝、代碼檢查工具配置、運(yùn)行和調(diào)試等步驟,需要的朋友可以參考下

記錄一下使用WebStorm開發(fā)Vu3項(xiàng)目時(shí)的配置

現(xiàn)在WebStorm可以個(gè)人免費(fèi)使用啦!??

基本配置

  • 打包工具:Vite
  • 前端框架:ElementPlus
  • 開發(fā)語言:Vue3、TypeScript、Sass
  • 代碼檢查:ESLint、Prettier
  • IDE:WebStorm 2024.2

首先說一下版本兼容問題,ElementPlus>=2.8.5需要Sass>=1.79.0,但是升級(jí)了Sass后,會(huì)導(dǎo)致Element提示很多警告,猜測(cè)原因是因?yàn)镾ass在后續(xù)版本修改了一些語法規(guī)則,而Element沒有跟進(jìn)修改。這些警告雖然不影響代碼運(yùn)行,但是看著糟心,目前只能等待官方后續(xù)更新了。

搭建Vue3項(xiàng)目

通過Vite搭建Vue3項(xiàng)目

npm create vite@latest my-vue-app -- --template vue-ts
  • my-vue-app為項(xiàng)目文件夾名稱
  • vue-ts表示使用包含typescript的vue項(xiàng)目模板搭建

安裝后的目錄結(jié)構(gòu)

├─ index.html
├─ package.json
├─ tsconfig.json #typescript配置文件
├─ tsconfig.app.json #typescript配置文件,本項(xiàng)目的ts配置,自動(dòng)引用到tsconfig.json中
├─ tsconfig.node.json #typescript配置文件,為vite服務(wù)的ts配置,自動(dòng)引用到tsconfig.json中
├─ vite.config.ts #vite配置文件
├─ src
│  ├─ assets #靜態(tài)文件
│  ├─ components #組件
│  ├─ App.vue
│  ├─ main.ts

安裝框架和其他工具包

修改項(xiàng)目根目錄下的package.json文件,添加前端框架和其他依賴包

{
  "name": "my-vue-app",
  "private": true,
  "version": "0.0.0",
  "type": "module",
  "scripts": {
    "dev": "vite",
    "build": "vue-tsc -b && vite build",
    "preview": "vite preview"
  },
  "dependencies": {
    "vue": "^3.5.12",
    "element-plus": "^2.8.1"
  },
  "devDependencies": {
    "@vitejs/plugin-vue": "^5.1.4",
    "typescript": "~5.6.2",
    "vite": "^5.4.10",
    "vue-tsc": "^2.1.8",
    "sass": "^1.77.0",
    "unplugin-auto-import": "^0.18.3",
    "unplugin-vue-components": "^0.27.4",
    "@eslint/js": "^9.13.0",
    "@rushstack/eslint-patch": "^1.10.4",
    "eslint-plugin-prettier": "^5.2.1",
    "eslint-plugin-promise": "^6.6.0",
    "eslint-plugin-vue": "^9.29.0",
    "typescript-eslint": "^8.10.0",
    "@vue/eslint-config-prettier": "^10.0.0",
    "@vue/eslint-config-typescript": "^14.1.1"
  }
}
  • unplugin-auto-importunplugin-vue-components為自動(dòng)導(dǎo)入工具,可在編寫代碼時(shí),可以無需import ref from 'vue'而直接使用ref,工具配置后會(huì)自動(dòng)導(dǎo)入組件。
  • 名稱中包含eslint的依賴包為ESLint規(guī)則,后續(xù)在eslint.config.js中配置。
  • 正如一開始所說,由于ElementPlus和Sass版本過高會(huì)出現(xiàn)警告的問題,所以目前安裝的低版本,等待官方修復(fù)問題后,再升級(jí)版本。

運(yùn)行安裝依賴

npm install

如果安裝時(shí)間過久,或者提示網(wǎng)絡(luò)超時(shí),可以切換npm源后再重新安裝

# 切換為淘寶鏡像
npm config set registry https://registry.npmmirror.com/

配置vite:vite.config.ts

import {defineConfig, loadEnv} from 'vite'
import vue from '@vitejs/plugin-vue'
import AutoImport from 'unplugin-auto-import/vite';
import {ElementPlusResolver} from "unplugin-vue-components/resolvers";
import Components from 'unplugin-vue-components/vite';
import path from 'path';

export default defineConfig(({ mode }) => {
	// 環(huán)境變量
    const env = loadEnv(mode, process.cwd(), '');
    return {
        plugins: [
            vue(),
            AutoImport({
            	// 自動(dòng)導(dǎo)入的組件
                imports: ['vue', 'vue-router'],
                // 解析器:當(dāng)前使用了ElementPlus的解析器
                resolvers: [ElementPlusResolver()],
                // 開啟eslint
                eslintrc: { enabled: true },
            }),
            Components({
            	// 解析器:當(dāng)前使用了ElementPlus的解析器
                resolvers: [ElementPlusResolver({ importStyle: 'sass' })],
                // 以下文件夾中的組件自動(dòng)導(dǎo)入
                dirs: ['src/components'],
            }),
        ],
        resolve: {
            alias: {
                // 設(shè)置路徑別名
                '@': path.resolve(__dirname, './src'),
            },
        },
        server: {
        	// 網(wǎng)絡(luò)請(qǐng)求代理
            proxy: {
                '/t/': {
                    target: env.VITE_SERVER,
                    changeOrigin: true,
                },
            },
        },
    };
});

運(yùn)行項(xiàng)目

npm run dev

運(yùn)行后會(huì)自動(dòng)生成文件auto-imports.d.tscomponents.d.ts,又因?yàn)锳utoImport開啟了eslintrc,還會(huì)生成文件.eslintrc-auto-import.json

配置eslint:eslint.config.ts

目前使用的eslint9版本,配置文件與之前版本的寫法可能不一致。

注意:WebStorm2024版本才支持eslint9版本的配置文件。

創(chuàng)建eslint配置文件eslint.config.js

import pluginJs from '@eslint/js';
import tseslint from 'typescript-eslint';
import pluginVue from 'eslint-plugin-vue';
import eslintPluginPrettierRecommended from 'eslint-plugin-prettier/recommended';
import autoImport from './.eslintrc-auto-import.json' assert { type: 'json' };

export default [
    { files: ['**/*.{js,mjs,cjs,ts,vue}'] },
    // 導(dǎo)入auto-import插件配置(目前暫不支持eslint9)
    { files: ['**/*.{js,mjs,cjs,ts,vue}'], languageOptions: autoImport },
    pluginJs.configs.recommended,
    ...tseslint.configs.recommended,
    ...pluginVue.configs['flat/essential'],
    { files: ['**/*.vue'], languageOptions: { parserOptions: { parser: tseslint.parser } } },
    // 自定義規(guī)則
    {
        rules: {
            // 使用any類型時(shí)提示警告
            '@typescript-eslint/no-explicit-any': 'warn',
        },
    },
    eslintPluginPrettierRecommended,
];
  • 由于目前unplugin-auto-import并不支持eslint9,所以需要導(dǎo)入.eslintrc-auto-import.json文件消除錯(cuò)誤提示。
  • 一般來說eslint-plugin-prettier的規(guī)則要放在最后,保證它的規(guī)則不會(huì)被覆蓋。
  • 如果要增加更多規(guī)則,請(qǐng)查看eslint配置文檔。

修改ts配置:tsconfig.app.json

修改ts配置,添加上一步自動(dòng)生成的.d.ts文件,添加后就不會(huì)提示Vue的導(dǎo)入錯(cuò)誤了。

# 在include中添加文件名
{
	"compilerOptions": {...}
	"include": [..., "auto-imports.d.ts", "components.d.ts"]
}

修改WebStorm設(shè)置

  • 選擇自動(dòng)ESLint配置,編輯器會(huì)自動(dòng)尋找根目錄下的.eslint.config.js文件。
  • 勾選eslint --fix會(huì)在保存文件時(shí)自動(dòng)格式化代碼。

     


    修改后重啟一下編輯器,或者重啟語言服務(wù)中的兩個(gè)服務(wù)。

完成后打開App.vue文件,刪除import HelloWorld from './components/HelloWorld.vue',并沒有HelloWorld組件未導(dǎo)入的錯(cuò)誤提示,則說明配置生效了。

配置prettier:.prettierrc.json

默認(rèn)prettier的規(guī)則可能不適合個(gè)人習(xí)慣,可以通過添加.prettierrc.json配置文件進(jìn)行修改規(guī)則

{
  "semi": true, 	// 句尾增加分號(hào)
  "tabWidth": 4,	//使用4個(gè)空格縮進(jìn)
  "singleQuote": true,	// 使用單引號(hào)
  "printWidth": 200,	// 超過200字符換行
  "arrowParens": "avoid",	// 單箭頭函數(shù)不加括號(hào)
  "bracketSameLine": true	// 對(duì)象前后增加空格
}

還有很多規(guī)則,可以查看prettier文檔。

環(huán)境變量env

創(chuàng)建文件.env.env.development、.env.production分別對(duì)應(yīng)默認(rèn)配置、開發(fā)環(huán)境配置、生成環(huán)境配置

// .env.development
VITE_SERVER = http://dev.xxx.com
// .env.production
VITE_SERVER = http://pro.xxx.com

修改打包命令

// package.json
{
	...
	"scripts":{
		...
	    "build": "vite build --mode production",
    	"build-dev": "vite build --mode development",
    	...
	}
	...
}

更多有關(guān)環(huán)境變量的配置和使用,請(qǐng)查看vite文檔。

其他問題

  • 為什么用了ESLint還要用Prettier,兩者分別有什么作用?
    Prettier用于格式化代碼,確??s進(jìn)、分號(hào)、引號(hào)、換行等代碼格式一致;ESLint則用于代碼語法檢測(cè),提示錯(cuò)誤。

總結(jié) 

到此這篇關(guān)于使用WebStorm開發(fā)Vue3項(xiàng)目的文章就介紹到這了,更多相關(guān)WebStorm開發(fā)Vue3項(xiàng)目內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談vue3在項(xiàng)目中的邏輯抽離和字段顯示

    淺談vue3在項(xiàng)目中的邏輯抽離和字段顯示

    本文主要介紹了vue3在項(xiàng)目中的邏輯抽離和字段顯示,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Vue實(shí)現(xiàn)文件上傳和下載功能

    Vue實(shí)現(xiàn)文件上傳和下載功能

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)文件上傳和下載功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • vue滾動(dòng)固定頂部及修改樣式的實(shí)例代碼

    vue滾動(dòng)固定頂部及修改樣式的實(shí)例代碼

    這篇文章主要介紹了vue滾動(dòng)固定頂部及修改樣式,本文給大家提到了滾動(dòng)固定位置有多種方法,感興趣的朋友跟隨小編一起看看吧
    2019-05-05
  • Vite打包性能優(yōu)化之開啟Gzip壓縮實(shí)踐過程

    Vite打包性能優(yōu)化之開啟Gzip壓縮實(shí)踐過程

    vue前端項(xiàng)目發(fā)布的時(shí)候,打包可實(shí)現(xiàn)gzip格式的壓縮,下面這篇文章主要給大家介紹了關(guān)于Vite打包性能優(yōu)化之開啟Gzip壓縮的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • vue實(shí)現(xiàn)簡單購物車案例

    vue實(shí)現(xiàn)簡單購物車案例

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡單購物車案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • vue 在單頁面應(yīng)用里使用二級(jí)套嵌路由

    vue 在單頁面應(yīng)用里使用二級(jí)套嵌路由

    這篇文章主要介紹了vue 在單頁面應(yīng)用里使用二級(jí)套嵌路由,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-12-12
  • vue3+elementPlus二次封裝表單的實(shí)現(xiàn)代碼

    vue3+elementPlus二次封裝表單的實(shí)現(xiàn)代碼

    最近使用Vue3+ElementPlus開發(fā)項(xiàng)目,從整體上構(gòu)思組件的封裝。能寫成組件的內(nèi)容都進(jìn)行封裝,方便多個(gè)地方使用,這篇文章給大家介紹了vue3+elementPlus二次封裝表單的實(shí)現(xiàn),并通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • vue.js初學(xué)入門教程(1)

    vue.js初學(xué)入門教程(1)

    這篇文章主要為大家詳細(xì)介紹了vue.js初學(xué)入門教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • 在vue中完美使用ueditor組件(cdn)解讀

    在vue中完美使用ueditor組件(cdn)解讀

    這篇文章主要介紹了在vue中完美使用ueditor組件(cdn)解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue引入cesium問題

    vue引入cesium問題

    這篇文章主要介紹了vue引入cesium問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10

最新評(píng)論