Vue3組件庫(kù)框架搭建example環(huán)境的詳細(xì)教程
前面用了大量篇幅介紹組件庫(kù)的開(kāi)發(fā)環(huán)境搭建,包括:創(chuàng)建組件、創(chuàng)建組件庫(kù)入口、組件庫(kù)樣式架構(gòu)、組件庫(kù)公共包,做了一大堆工作,還不能預(yù)覽示例組件 foo,本文便搭建 example 開(kāi)發(fā)環(huán)境和打包構(gòu)建,并在 example 中使用組件庫(kù)。
1 搭建 example 開(kāi)發(fā)環(huán)境
1.1 創(chuàng)建 example 項(xiàng)目
example 本質(zhì)上就是一個(gè) vite3 + vue3 的項(xiàng)目,可以通過(guò) vite 來(lái)創(chuàng)建,也可以通過(guò)優(yōu)雅哥編寫的 yyg-cli 來(lái)創(chuàng)建一個(gè)全家桶項(xiàng)目,甚至可以手動(dòng)搭建。后面程序員優(yōu)雅哥會(huì)用 example 來(lái)實(shí)現(xiàn)一個(gè)完整的企業(yè)級(jí)中后臺(tái)管理項(xiàng)目,用它來(lái)驅(qū)動(dòng)組件庫(kù)的組件開(kāi)發(fā)。
簡(jiǎn)單一些,這里就使用 vite 來(lái)創(chuàng)建 example 項(xiàng)目。從命令行中進(jìn)入 example 目錄,運(yùn)行:
pnpm create vite
- 輸入該命令后,稍等一會(huì)兒會(huì)提示輸入 project name,由于咱們已經(jīng)創(chuàng)建 example 目錄,這里輸入一個(gè)點(diǎn)(.)即可;
- framework 選擇 Vue;
- variant 選擇 TypeScript。
1.2 修改 package.json
生成項(xiàng)目后,先不要著急安裝依賴,因?yàn)橛行┮蕾囈呀?jīng)在 workspace-root 中安裝了,在這個(gè)子模塊中便無(wú)需重復(fù)安裝。
修改 package.json 的 name、dependencies、devDependencies,修改后內(nèi)容如下:
{
"name": "@yyg-demo-ui/example",
...
"dependencies": {
},
"devDependencies": {
"@vitejs/plugin-vue": "^3.2.0",
"typescript": "^4.6.4"
}
}1.3 修改 vite 配置文件
自動(dòng)生成的 vite.config.ts 文件只配置了 vue 插件,咱需要對(duì)其進(jìn)行其他配置,如 TSX 插件、ESLint 插件、路徑別名等:
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import path from 'path'
import eslint from 'vite-plugin-eslint'
import vueJsx from '@vitejs/plugin-vue-jsx'
export default defineConfig({
plugins: [
vue(),
vueJsx(),
eslint()
],
resolve: {
alias: {
'@': path.resolve(__dirname, 'src')
}
},
server: {
port: 3000,
cors: true,
proxy: {}
},
build: {
outDir: path.resolve(__dirname, '../dist')
}
})1.4 多環(huán)境支持
這一步非必須,只是為了后面的項(xiàng)目開(kāi)發(fā)做準(zhǔn)備的。多環(huán)境支持在之前的文章中已經(jīng)詳細(xì)講過(guò),各位可以翻閱之前的文章,這里僅快速操作一遍。
- 在 example 目錄下創(chuàng)建 env 目錄,并在該目錄中分別創(chuàng)建四個(gè)文件:
VITE_BASE_API=/api VITE_APP_NAME='demo app'
example/env/.env.dev:
VITE_BASE_API=/dev-api NODE_ENV=production
example/env/.env.uat:
VITE_BASE_API=/uat-api
example/env/.env.prod:
VITE_BASE_API=/prod-api
- 在 vite.config.ts 中指定環(huán)境文件目錄:
export default defineConfig({
...
envDir: path.resolve(__dirname, 'env'),
...
})- 在 src 中創(chuàng)建 env.d.ts 文件,以便于類型提示:
/// <reference types="vite/client" />
interface ImportMetaEnv {
readonly VITE_BASE_API: string;
readonly VITE_APP_NAME: string;
}
// eslint-disable-next-line no-unused-vars
interface ImportMeta {
readonly env: ImportMetaEnv
}- 修改 package.json 的 scripts:
{
...
"scripts": {
"dev:dev": "vite --mode dev",
"dev:uat": "vite --mode uat",
"dev:prod": "vite --mode prod",
"build:dev": "vue-tsc --noEmit && vite build --mode dev",
"build:uat": "vue-tsc --noEmit && vite build --mode uat",
"build:prod": "vue-tsc --noEmit && vite build --mode prod",
"preview": "vite preview"
},
...
}- 在 main.ts 中測(cè)試輸入環(huán)境變量:
const env = import.meta.env console.log(env)
1.5 測(cè)試啟動(dòng)服務(wù)
執(zhí)行 pnpm run dev:dev,測(cè)試服務(wù)是否能正常啟動(dòng),然后在瀏覽器中訪問(wèn) localhost:3000,測(cè)試界面是否正常,環(huán)境變量是否正常輸出。
2 測(cè)試 foo 組件
example 能正常運(yùn)行后,說(shuō)明 example 已經(jīng)初始化成功,接下來(lái)便需要測(cè)試前面開(kāi)發(fā)的 foo 組件了。
2.1 安裝依賴
由于自定義組件庫(kù)依賴于 element-plus,首先需要在 example 中安裝 element-plus:
pnpm install element-plus
接著安裝咱們的本地組件庫(kù) @yyg-demo-ui/yyg-demo-ui:
pnpm install @yyg-demo-ui/yyg-demo-ui
此時(shí) example 的 package.json dependencies 如下:
"dependencies": {
"@yyg-demo-ui/yyg-demo-ui": "workspace:^1.0.0",
"element-plus": "^2.2.21"
},2.2 引入組件庫(kù)
在 main.ts 中分別引入 element-plus 和 自定義組件庫(kù):
...
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import YygDemoUi from '@yyg-demo-ui/yyg-demo-ui'
...
const app = createApp(App)
app.use(ElementPlus)
app.use(YygDemoUi)
app.mount('#app')2.3 使用組件
項(xiàng)目創(chuàng)建時(shí)自動(dòng)在 src/style.css 生成了很多樣式,可以將里面的內(nèi)容都刪除,留下一個(gè)空的 style.css 文件。
最后只需在 App.vue 中測(cè)試 foo 組件即可,修改 App.vue 如下:
<template>
<div class="site">
<h1>組件庫(kù)測(cè)試站點(diǎn) yyg-demo-ui</h1>
<p>測(cè)試站點(diǎn)主要用于開(kāi)發(fā)過(guò)程中測(cè)試組件,即在開(kāi)發(fā)過(guò)程中由業(yè)務(wù)驅(qū)動(dòng)組件開(kāi)發(fā)。</p>
<yyg-foo :msg="msg"></yyg-foo>
</div>
</template>
<script setup lang="ts">
import { ref } from 'vue'
const msg = ref('hello world')
</script>
<style scoped lang="scss">
.site {
padding: 20px;
}
</style>2.4 運(yùn)行查看效果
再次運(yùn)行 pnpm run dev:dev,查看效果:

foo 組件的樣式、功能、以及 testLog 函數(shù)都正常運(yùn)行,則 example 和 組件庫(kù)的開(kāi)發(fā)環(huán)境便已完成。
3 example 打包構(gòu)建
在前面的 scripts 中添加了 build:dev、build:uat、build:prod命令,分別對(duì)應(yīng)dev、uat、prod 三個(gè)環(huán)境,咱們就以 dev 環(huán)境為例說(shuō)明 example的打包構(gòu)建。
從命令行中進(jìn)入 example 目錄,依次進(jìn)行打包構(gòu)建、預(yù)覽:
- 執(zhí)行 pnpm run build:dev 進(jìn)行打包,打包構(gòu)建成功后,會(huì)在整個(gè)項(xiàng)目的根目錄下生成 dist 目錄(該目錄在 vite.config.ts 中 build.outDir 配置);
- 執(zhí)行 pnpm run preview 對(duì)打包后的文件進(jìn)行預(yù)覽,訪問(wèn)控制臺(tái)中輸出的端口,運(yùn)行效果與上面的效果一致。
到這里,example 的開(kāi)發(fā)和構(gòu)建便已經(jīng)完成,咱們可以在 example 中使用組件庫(kù)的組件。下文將介紹組件庫(kù)文檔的開(kāi)發(fā)和構(gòu)建。
到此這篇關(guān)于Vue3組件庫(kù)框架搭建example環(huán)境的文章就介紹到這了,更多相關(guān)vue搭建example環(huán)境內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決Vue + Echarts 使用markLine標(biāo)線(precision精度問(wèn)題)
這篇文章主要介紹了解決Vue + Echarts 使用markLine標(biāo)線(precision精度問(wèn)題),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
Vue.JS實(shí)現(xiàn)垂直方向展開(kāi)、收縮不定高度模塊的JS組件
這篇文章主要介紹了Vue.JS實(shí)現(xiàn)垂直方向展開(kāi)、收縮不定高度模塊的JS組件,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06
vuex實(shí)現(xiàn)登錄狀態(tài)的存儲(chǔ),未登錄狀態(tài)不允許瀏覽的方法
下面小編就為大家分享一篇vuex實(shí)現(xiàn)登錄狀態(tài)的存儲(chǔ),未登錄狀態(tài)不允許瀏覽的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
element編輯表單el-radio回顯之后無(wú)法選擇的問(wèn)題解決
今天主要來(lái)談一下element-ui編輯表單中的el-radio回顯之后無(wú)法選擇的問(wèn)題,主要涉及到vue的雙向綁定,以及element-ui編輯表單中的el-radio的默認(rèn)類型,感興趣的可以了解一下2021-08-08
關(guān)于elementUi表格合并行數(shù)據(jù)并展示序號(hào)
這篇文章主要介紹了關(guān)于elementUi表格合并行數(shù)據(jù)并展示序號(hào),通過(guò)給table傳入span-method方法可以實(shí)現(xiàn)合并行或列,方法的參數(shù)是一個(gè)對(duì)象,感興趣的朋友可以學(xué)習(xí)一下2023-04-04
在vue中通過(guò)render函數(shù)給子組件設(shè)置ref操作
這篇文章主要介紹了在vue中通過(guò)render函數(shù)給子組件設(shè)置ref操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
vue.js el-tooltip根據(jù)文字長(zhǎng)度控制是否提示toolTip問(wèn)題
這篇文章主要介紹了vue.js el-tooltip根據(jù)文字長(zhǎng)度控制是否提示toolTip問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02

