從零開始在NPM上發(fā)布一個(gè)Vue組件的方法步驟
TL;DR 本文細(xì)致講解了在NPM上發(fā)布一個(gè)Vue組件的全過程,包括創(chuàng)建項(xiàng)目、編寫組件、打包和發(fā)布四個(gè)環(huán)節(jié)。
創(chuàng)建項(xiàng)目
這里我們直接利用@vue/cli來生成項(xiàng)目。如果沒有安裝@vue/cli的話,可以使用以下方法進(jìn)行安裝:
# 如果喜歡npm npm i -g @vue/cli # 如果喜歡yarn yarn global add @vue/cli
此外,如果安裝了npx(高版本的nodejs發(fā)行版會(huì)自帶這一工具)的話,還可以很方便地通過npx vue這一方式實(shí)現(xiàn)免安裝使用。
接下來就可以創(chuàng)建項(xiàng)目了,這里我們創(chuàng)建一個(gè)my-banner項(xiàng)目,里面將會(huì)包含一個(gè)Banner組件:
vue create my-banner
@vue/cli會(huì)提示你選擇一個(gè)預(yù)置(preset)的配置,這里我們直接選擇“default”(babel, eslint)就可以,之后@vue/cli會(huì)自動(dòng)調(diào)用yarn或npm來進(jìn)行依賴的下載。下載完成后就可以進(jìn)入項(xiàng)目目錄了:
cd my-banner
此時(shí)的目錄結(jié)構(gòu)為:
├── README.md ├── babel.config.js ├── node_modules ├── package.json ├── public │ ├── favicon.ico │ └── index.html ├── src │ ├── App.vue │ ├── assets │ ├── components │ └── main.js └── yarn.lock
下面啟動(dòng)開發(fā)環(huán)境本地服務(wù)器:
yarn serve
打開localhost:8080,就可以看到默認(rèn)的首頁:
@vue/cli 3.0自動(dòng)生成的默認(rèn)首頁
編寫組件
我們現(xiàn)在開始編寫一個(gè)非常簡單的Banner組件。
<!-- src/components/Banner.vue --> <template> <div class="banner" :style="bannerStyles" :class="`banner__${position}`"> <slot></slot> </div> </template> <script> const defaultStyles = { left: 0, right: 0, }; export default { props: { position: { type: String, default: 'top', validator(position) { return ['top', 'bottom'].indexOf(position) > -1; }, }, styles: { type: Object, default: () => ({}), }, }, data() { return { bannerStyles: { ...defaultStyles, ...this.styles, }, }; }, }; </script> <style lang="scss" scoped> .banner { padding: 12px; background-color: #fcf6cd; color: #f6a623; text-align: left; position: fixed; z-index: 2; } .banner__top { top: 0; } .banner__bottom { bottom: 0; } </style>
我們將Banner.vue置于src/components目錄下,同時(shí)在該目錄下新建一個(gè)index.js文件,用來注冊(cè)Vue組件。
// src/components/index.js import Vue from "vue"; import Banner from "./Banner.vue"; const Components = { Banner }; Object.keys(Components).forEach(name => { Vue.component(name, Components[name]); }); export default Components;
接下來我們修改一下@vue/cli自動(dòng)生成的src/components/HelloWorld.vue文件,引用一下我們剛剛編寫的Banner組件:
<!-- src/components/HelloWorld.vue --> <template> <div class="hello"> <!-- 下面插入了我們剛剛編寫的Banner組件 --> <Banner>This is a banner!</Banner> <h1>{{ msg }}</h1> <p> For a guide and recipes on how to configure / customize this project,<br> check out the <a rel="external nofollow" target="_blank" rel="noopener">vue-cli documentation</a>. </p> <!-- 省略部分內(nèi)容 --> </div> </template> <script> <!-- 省略有關(guān)內(nèi)容 --> </script> <!-- Add "scoped" attribute to limit CSS to this component only --> <style scoped> <!-- 省略有關(guān)內(nèi)容 --> </style>
修改一下項(xiàng)目的主入口main.js
// src/main.js import Vue from 'vue'; import App from './App.vue'; // 引用我們的自定義組件 import "./components"; Vue.config.productionTip = false; new Vue({ render: h => h(App), }).$mount('#app');
因?yàn)榍懊娑xstyle時(shí)使用了scss,所以還需要安裝兩個(gè)開發(fā)環(huán)境依賴項(xiàng)
yarn add sass-loader node-sass -D
最后執(zhí)行
yarn serve
就可以在localhost:8080看到效果了:
添加Banner后的頁面效果
可以看到,我們編寫的Banner組件已經(jīng)成功在頁面上渲染出來了。
打包
接下來,我們需要對(duì)這個(gè)組件進(jìn)行打包。這里我們可以使用@vue/cli 3.0自帶的打包功能。打開package.json文件,在scripts中增加一項(xiàng):
{ "scripts": { "package": "vue-cli-service build --target lib --name my-banner ./src/components/index.js" } }
然后執(zhí)行yarn package,會(huì)在dist目錄下生成下列文件:
├── demo.html ├── my-banner.common.js ├── my-banner.common.js.map ├── my-banner.css ├── my-banner.umd.js ├── my-banner.umd.js.map ├── my-banner.umd.min.js └── my-banner.umd.min.js.map
接下來,需要將package.json中的main字段指向剛剛生成的庫文件。這里以commonjs為例(umd應(yīng)該也是沒問題的):
{ "main": "./dist/my-banner.common.js" }
然后,我們需要在package.json的files字段中聲明這個(gè)組件庫項(xiàng)目需要包含的文件:
{ "files": [ "dist/*", "src/*", "public/*", "*.json", "*.js" ] }
這樣就可以打包階段就算是完成了。
發(fā)布
注冊(cè)NPM賬號(hào)并創(chuàng)建組織
首先登陸NPM官網(wǎng)
npmjs.com
注冊(cè)賬號(hào),都是常規(guī)操作,需要填寫的有全名、郵箱、用戶名和密碼。之后郵箱會(huì)收到確認(rèn)郵件,標(biāo)題為“Verify your npm email address”,發(fā)件人是“npm, Inc.”,點(diǎn)擊郵件中的鏈接就可以激活賬戶了。
登錄賬號(hào),點(diǎn)擊右上角的頭像,選擇“Create an Organization”,就可以創(chuàng)建你自己的組織了。
創(chuàng)建組織
組織有兩種選項(xiàng),支持私有發(fā)布的需要繳納每月7刀的“管理費(fèi)”,而我們現(xiàn)在只需要發(fā)布一個(gè)公共的包,那就可以選擇免費(fèi)版本。
選擇公開組織
本地命令行登陸npm
npm login
之后按提示輸入用戶名和密碼即可。
可以使用
npm whoami
來檢查登陸是否成功。如果成功的話,這條命令會(huì)返回你的用戶名。
給你的組件庫命名
你需要給你的這個(gè)組件庫起一個(gè)名字,這里用到的是package.json中的name字段。注意@后的名稱就填寫你剛剛創(chuàng)建的組織的名稱。
{ "name": "@abc/my-banner" }
最終步驟:再次構(gòu)建與發(fā)布
最后,使用yarn package
重新構(gòu)建一遍這個(gè)組件庫,然后使用:
npm publish --access public
來發(fā)布這個(gè)組件庫。
注意這里可能會(huì)報(bào)下面的錯(cuò)誤
npm ERR! This package has been marked as private
npm ERR! Remove the 'private' field from the package.json to publish it.
解決辦法很簡單,按照提示刪除package.json中的private字段,或?qū)⑵湓O(shè)置為false都可以。
成果
順利發(fā)布后,就可以在你的組織頁面看到剛剛發(fā)布的這個(gè)包了。
發(fā)布成功
在此之后,你可以新建一個(gè)項(xiàng)目,然后
yarn add @abc/my-banner
來把你剛剛發(fā)布的這個(gè)包添加為依賴項(xiàng)。由于我們之前已經(jīng)在src/components/index.js中對(duì)組件進(jìn)行了全局注冊(cè),所以你現(xiàn)在可以直接在template中調(diào)用<Banner>。
總結(jié)
以上,我們就從零開始實(shí)現(xiàn)了一個(gè)Vue組件在npm上發(fā)布的流程,是不是很簡單呢?那么,現(xiàn)在就開始發(fā)布一個(gè)你自己的組件吧!希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家
參考文章
How to create and publish your own VueJS Component library on NPM using @vue/cli 3.0
相關(guān)文章
vue+axios 前端實(shí)現(xiàn)的常用攔截的代碼示例
這篇文章主要介紹了vue+axios 前端實(shí)現(xiàn)的常用攔截的代碼示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-08-08Vue3利用組合式函數(shù)和Shared Worker實(shí)現(xiàn)后臺(tái)分片上傳
這篇文章主要為大家詳細(xì)介紹了Vue3如何利用組合式函數(shù)和Shared Worker實(shí)現(xiàn)后臺(tái)分片上傳(帶哈希計(jì)算),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-10-10Vue?ElementUI在el-table中使用el-popover問題
這篇文章主要介紹了Vue?ElementUI在el-table中使用el-popover問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04vue3組合式API實(shí)現(xiàn)todo列表效果
這篇文章主要介紹了vue3組合式API實(shí)現(xiàn)todo列表,下面用組合式?API的寫法,實(shí)現(xiàn)一個(gè)可新增、刪除的todo列表效果,需要的朋友可以參考下2024-08-08Vue.js一個(gè)文件對(duì)應(yīng)一個(gè)組件實(shí)踐
Vue.js實(shí)現(xiàn)"一個(gè)文件對(duì)應(yīng)一個(gè)組件",無需webpack等工具,按需加載組件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10Vue3項(xiàng)目中引用TS語法的實(shí)例講解
這篇文章主要介紹了Vue3項(xiàng)目中引用TS語法的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05Vue使用el-table實(shí)現(xiàn)表格跨頁多選
在我們?nèi)粘m?xiàng)目開發(fā)中,經(jīng)常會(huì)有表格跨頁多選的需求,接下來讓我們用?el-table示例一步步來實(shí)現(xiàn)這個(gè)需求,文中有詳細(xì)的代碼講解,對(duì)我們的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-08-08