国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

基于vue如何發布一個npm包的方法步驟

2019-11-19 11:34:16
字體:
來源:轉載
供稿:網友

前言:工作的時候總是使用別人的npm包,然而我有時心底會好奇自己如何發布一個npm包呢,什么時候自己的包能夠被很多人喜歡并使用呢...今天我終于邁出了第一步。

前提:會使用 npm,有 vue 基礎,了解一點 webpack

Are you ready? Go!

一、編寫自己的npm包

1. 新建一個空文件夾

2. 進入文件夾,終端(cmd)運行 npm init

完成后會在目錄下生成一個 package.json 文件

我們可以根據自己的需要補充文件內容

這是我的:

{ "name": "bing-test-publish-npm", "version": "1.0.0", "description": "布一個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. 配置完后,命令行運行 npm install 安裝依賴包,安裝完會生成一個node_modules目錄

4. 接下來新建兩個文件夾 src(開發目錄),dist(發布目錄)

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")      }    })  ]}

文件寫好后,我們運行 npm run build,結果是會在 dist 目錄下生成一個helloName.min.js,就是我們在 webpack.dev.conf.js 中 filename 的值

6. 將 package.json 中的 main 字段指向新生成的 helloName.min.js

7. 新建一個.npmignore文件(npm忽略文件),可以把不需要發布的文件忽略,如果只有 .gitignore,沒有 .npmignore,則會使用 .gitignore

如:

.**.md*.ymlbuild/node_modules/src/test/gulpfile.js

二、發布npm包

1. 到 https://www.npmjs.com 注冊一個賬號

2. 進入你的項目根目錄,運行 npm login

會輸入你的用戶名、密碼和郵箱

3. 登錄成功后,執行 npm publish,就發布成功啦,我們可以在官網看到

三、使用自己的npm包

接下來我們在其他項目中使用自己剛發布的npm包

1. 我們進入我們的項目目錄運行 npm(或cnpm) installbing-test-publish-npm(我們剛發布的包)

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>

這時我發現我的控制臺報錯了,原來是編碼錯誤,因此,我們需要修改更新代碼

<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版本

規則:對于"version":"x.y.z"

1.修復bug,小改動,增加z

2.增加了新特性,但仍能向后兼容,增加y

3.有很大的改動,無法向后兼容,增加x  

2. 修改后 運行 npm run build, npm publish 就成功更新了包的版本

3. 使用時需要

  • 卸載之前安裝的包 npm uninstallbing-test-publish-npm
  • 重新安裝 npm installbing-test-publish-npm
  • 可通過 npm listbing-test-publish-npm 查看到版本已是最新的版本

五、最終效果

  

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 彰武县| 霍山县| 阳高县| 呼和浩特市| 九江市| 安宁市| 房山区| 泽州县| 同仁县| 商水县| 怀化市| 繁峙县| 博罗县| 阿拉善右旗| 新竹县| 竹山县| 嘉定区| 凤翔县| 汶上县| 余江县| 邳州市| 叶城县| 德州市| 漯河市| 苏尼特右旗| 行唐县| 民丰县| 沾益县| 沁阳市| 星座| 阳城县| 霍邱县| 石棉县| 偃师市| 同心县| 达尔| 略阳县| 延津县| 白朗县| 丰宁| 鹿邑县|