基于vue如何發(fā)布一個(gè)npm包的方法步驟
前言:工作的時(shí)候總是使用別人的npm包,然而我有時(shí)心底會(huì)好奇自己如何發(fā)布一個(gè)npm包呢,什么時(shí)候自己的包能夠被很多人喜歡并使用呢...今天我終于邁出了第一步。
前提:會(huì)使用 npm,有 vue 基礎(chǔ),了解一點(diǎn) webpack
Are you ready? Go!
一、編寫自己的npm包
1. 新建一個(gè)空文件夾
2. 進(jìn)入文件夾,終端(cmd)運(yùn)行 npm init

完成后會(huì)在目錄下生成一個(gè) package.json 文件
我們可以根據(jù)自己的需要補(bǔ)充文件內(nèi)容
這是我的:
{
"name": "bing-test-publish-npm",
"version": "1.0.0",
"description": "布一個(gè)npm包",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"start": "webpack-dev-server --hot --inline",
"build": "webpack --display-error-details --config webpack.config.js"
},
"author": "bing",
"license": "ISC",
"devDependencies": {
"babel-core": "^6.26.0",
"babel-loader": "^7.1.2",
"babel-plugin-transform-object-rest-spread": "^6.26.0",
"babel-plugin-transform-runtime": "^6.23.0",
"babel-polyfill": "^6.26.0",
"babel-preset-es2015": "^6.24.1",
"css-loader": "^0.28.7",
"es6-promise": "^4.1.1",
"less": "^2.7.3",
"less-loader": "^4.0.5",
"style-loader": "^0.19.0",
"url-loader": "^0.6.2",
"vue": "^2.5.9",
"vue-hot-reload-api": "^2.2.4",
"vue-html-loader": "^1.2.4",
"vue-loader": "^13.5.0",
"vue-router": "^3.0.1",
"vue-style-loader": "^3.0.3",
"vue-template-compiler": "^2.5.9",
"vuex": "^3.0.1",
"webpack": "^3.9.1",
"webpack-dev-server": "^2.9.5"
}
}
3. 配置完后,命令行運(yùn)行 npm install 安裝依賴包,安裝完會(huì)生成一個(gè)node_modules目錄
4. 接下來新建兩個(gè)文件夾 src(開發(fā)目錄),dist(發(fā)布目錄)
5. 然后我們就可以在 src 目錄下編寫自己的組件吧
我的文件目錄

app.vue
<template>
<div class="helloName">
<input type="text" placeholder="請輸入姓名" v-model="yourName"></input>
<div v-if="name">hello<span class="name">{{name}}!</span></div>
</div>
</template>
<script>
export default {
name:'helloName',
data () {
return {
yourName: ''
}
},
methods: {
},
created(){
}
}
</script>
<style>
</style>
index.js
import helloName from './app.vue' export default helloName
webpack.dev.conf.js
const path = require("path");
const webpack = require("webpack");
const uglify = require("uglifyjs-webpack-plugin");
module.exports = {
devtool: 'source-map',
entry: "./src/index.js",//入口文件,src目錄下的index.js文件,
output: {
path: path.resolve(__dirname, './dist'),//輸出路徑,就是新建的dist目錄,
publicPath: '/dist/',
filename: 'helloName.min.js',
libraryTarget: 'umd',
umdNamedDefine: true
},
module: {
rules: [{
test: /\.vue$/,
loader: 'vue-loader'
},
{
test: /\.less$/,
use: [
{ loader: "style-loader" },
{ loader: "css-loader" },
{ loader: "less-loader" }
]
},
{
test: /\.js$/,
exclude: /node_modules|vue\/dist|vue-router\/|vue-loader\/|vue-hot-reload-api\//,
loader: 'babel-loader'
},
{
test: /\.(png|jpg|gif|ttf|svg|woff|eot)$/,
loader: 'url-loader',
query: {
limit: 30000,
name: '[name].[ext]?[hash]'
}
}
]
},
plugins: [
new webpack.DefinePlugin({
"process.env": {
NODE_ENV: JSON.stringify("production")
}
})
]
}
文件寫好后,我們運(yùn)行 npm run build,結(jié)果是會(huì)在 dist 目錄下生成一個(gè)helloName.min.js,就是我們在 webpack.dev.conf.js 中 filename 的值

6. 將 package.json 中的 main 字段指向新生成的 helloName.min.js
7. 新建一個(gè).npmignore文件(npm忽略文件),可以把不需要發(fā)布的文件忽略,如果只有 .gitignore,沒有 .npmignore,則會(huì)使用 .gitignore
如:
.* *.md *.yml build/ node_modules/ src/ test/ gulpfile.js
二、發(fā)布npm包
1. 到 https://www.npmjs.com 注冊一個(gè)賬號
2. 進(jìn)入你的項(xiàng)目根目錄,運(yùn)行 npm login
會(huì)輸入你的用戶名、密碼和郵箱
3. 登錄成功后,執(zhí)行 npm publish,就發(fā)布成功啦,我們可以在官網(wǎng)看到

三、使用自己的npm包
接下來我們在其他項(xiàng)目中使用自己剛發(fā)布的npm包
1. 我們進(jìn)入我們的項(xiàng)目目錄運(yùn)行 npm(或cnpm) installbing-test-publish-npm(我們剛發(fā)布的包)

2. 在需要使用此包的頁面引入,并使用
<template>
<div>
我的npm包
<helloName></helloName>
</div>
</template>
<script>
import helloName from 'bing-test-publish-npm'
export default {
name: 'npm',
data () {
return {
}
},
components: {
helloName
}
}
</script>
這時(shí)我發(fā)現(xiàn)我的控制臺(tái)報(bào)錯(cuò)了,原來是編碼錯(cuò)誤,因此,我們需要修改更新代碼
<template>
<div class="helloName">
<input type="text" placeholder="請輸入姓名" v-model="yourName"></input>
<div v-if="yourName">hello<span class="name">{{yourName}}!</span></div>
</div>
</template>
<script>
export default {
name:'helloName',
data () {
return {
yourName: ''
}
},
methods: {
},
created(){
}
}
</script>
<style>
</style>
四、更新npm包
1. 修改完代碼后,我們需要修改 package.json 的version版本
規(guī)則:對于"version":"x.y.z"
1.修復(fù)bug,小改動(dòng),增加z
2.增加了新特性,但仍能向后兼容,增加y
3.有很大的改動(dòng),無法向后兼容,增加x
2. 修改后 運(yùn)行 npm run build, npm publish 就成功更新了包的版本
3. 使用時(shí)需要
- 卸載之前安裝的包 npm uninstallbing-test-publish-npm
- 重新安裝 npm installbing-test-publish-npm
- 可通過 npm listbing-test-publish-npm 查看到版本已是最新的版本
五、最終效果

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
VUE使用DXFParser組件解析dxf文件生成圖片的操作代碼
這篇文章主要介紹了VUE使用DXFParser組件解析dxf文件生成圖片的操作代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09
vue el-table實(shí)現(xiàn)行內(nèi)編輯功能
這篇文章主要為大家詳細(xì)介紹了vue el-table實(shí)現(xiàn)行內(nèi)編輯功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
vue項(xiàng)目及axios請求獲取數(shù)據(jù)方式
這篇文章主要介紹了vue項(xiàng)目及axios請求獲取數(shù)據(jù)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
vue2.x 從vue.config.js配置到項(xiàng)目優(yōu)化
這篇文章主要介紹了vue2.x 從vue.config.js配置到項(xiàng)目優(yōu)化,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04

