從零開始在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)用yarnnpm來進(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文件,用來注冊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  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.jsonfiles字段中聲明這個(gè)組件庫項(xiàng)目需要包含的文件:

{
  "files": [
    "dist/*",
    "src/*",
    "public/*",
    "*.json",
    "*.js"
  ]
}

這樣就可以打包階段就算是完成了翅阵。

發(fā)布

注冊NPM賬號(hào)并創(chuàng)建組織

首先登陸NPM官網(wǎng)

npmjs.com

注冊賬號(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)行了全局注冊秕噪,所以你現(xiàn)在可以直接在template中調(diào)用<Banner>钳降。

總結(jié)

以上,我們就從零開始實(shí)現(xiàn)了一個(gè)Vue組件在npm上發(fā)布的流程巢价,是不是很簡單呢牲阁?那么,現(xiàn)在就開始發(fā)布一個(gè)你自己的組件吧壤躲!


參考文章

How to create and publish your own VueJS Component library on NPM using @vue/cli 3.0

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末城菊,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子碉克,更是在濱河造成了極大的恐慌凌唬,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件漏麦,死亡現(xiàn)場離奇詭異客税,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)撕贞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門更耻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人捏膨,你說我怎么就攤上這事秧均。” “怎么了号涯?”我有些...
    開封第一講書人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵目胡,是天一觀的道長。 經(jīng)常有香客問我链快,道長誉己,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任域蜗,我火速辦了婚禮巨双,結(jié)果婚禮上噪猾,老公的妹妹穿的比我還像新娘。我一直安慰自己筑累,他們只是感情好畏妖,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著疼阔,像睡著了一般。 火紅的嫁衣襯著肌膚如雪半夷。 梳的紋絲不亂的頭發(fā)上婆廊,一...
    開封第一講書人閱讀 51,146評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音巫橄,去河邊找鬼淘邻。 笑死,一個(gè)胖子當(dāng)著我的面吹牛湘换,可吹牛的內(nèi)容都是我干的宾舅。 我是一名探鬼主播,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼彩倚,長吁一口氣:“原來是場噩夢啊……” “哼筹我!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起帆离,我...
    開封第一講書人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤蔬蕊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后哥谷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體岸夯,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年们妥,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了猜扮。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡监婶,死狀恐怖旅赢,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情压储,我是刑警寧澤鲜漩,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站集惋,受9級(jí)特大地震影響孕似,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜刮刑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一喉祭、第九天 我趴在偏房一處隱蔽的房頂上張望养渴。 院中可真熱鬧,春花似錦泛烙、人聲如沸理卑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽藐唠。三九已至,卻和暖如春鹉究,著一層夾襖步出監(jiān)牢的瞬間宇立,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來泰國打工自赔, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留妈嘹,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓绍妨,卻偏偏與公主長得像润脸,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子他去,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • 前言 入行前端也不少時(shí)間了毙驯,之前一直都在使用npm install別人的模塊/組件,那么作為一名有追求的前端肯定不...
    LinDaiDai_霖呆呆閱讀 1,922評(píng)論 0 0
  • 這個(gè)世界上允坚,哪有這么多篤定的一成不變,如果想要幸福蛾号,就要不斷地改變稠项,改變自己不好的心性,遷就自己的懦弱鲜结,成全自己的...
    程零下閱讀 1,610評(píng)論 46 23
  • 2018.6.4 今天去照形象照展运,內(nèi)心波動(dòng)好大,之前的修行精刷,感覺有些白修了拗胜,自己的傲心、躁心都冒出來了怒允,回饋的方式...
    若嘉閱讀 308評(píng)論 2 2