欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2019年05月15日 09:22:33   作者:餅餅醬~  
這篇文章主要介紹了基于vue如何發(fā)布一個npm包的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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

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

Are you ready? Go!

一、編寫自己的npm包

1. 新建一個空文件夾

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

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

我們可以根據(jù)自己的需要補充文件內(nèi)容

這是我的:

{
 "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(開發(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")
      }
    })
  ]
}

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

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

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

如:

.*
*.md
*.yml
build/
node_modules/
src/
test/
gulpfile.js

二、發(fā)布npm包

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

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

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

3. 登錄成功后,執(zhí)行 npm publish,就發(fā)布成功啦,我們可以在官網(wǎng)看到

三、使用自己的npm包

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

1. 我們進入我們的項目目錄運行 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>

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

<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,小改動,增加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 查看到版本已是最新的版本

五、最終效果

  

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 解決vue無法設(shè)置滾動位置的問題

    解決vue無法設(shè)置滾動位置的問題

    這篇文章主要介紹了解決vue無法設(shè)置滾動位置的問題 ,需要的朋友可以參考下
    2018-10-10
  • Vue.js實現(xiàn)簡單ToDoList 前期準備(一)

    Vue.js實現(xiàn)簡單ToDoList 前期準備(一)

    這篇文章主要介紹了Vue.js實現(xiàn)簡單ToDoList的前期準備,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • 淺談vue websocket nodeJS 進行實時通信踩到的坑

    淺談vue websocket nodeJS 進行實時通信踩到的坑

    這篇文章主要介紹了淺談vue websocket nodeJS 進行實時通信踩到的坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • element-ui table組件如何使用render屬性的實現(xiàn)

    element-ui table組件如何使用render屬性的實現(xiàn)

    這篇文章主要介紹了element-ui table組件如何使用render屬性的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • vue登錄注冊實例詳解

    vue登錄注冊實例詳解

    在本篇內(nèi)容里小編給大家分享的是關(guān)于vue登錄注冊的相關(guān)實例內(nèi)容以及寫法分析,有需要朋友們可以學(xué)習(xí)下。
    2019-09-09
  • vue實現(xiàn)登錄時圖形驗證碼

    vue實現(xiàn)登錄時圖形驗證碼

    這篇文章主要為大家詳細介紹了vue實現(xiàn)登錄時圖形驗證碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue實現(xiàn)遠程獲取路由與頁面刷新導(dǎo)致404錯誤的解決

    Vue實現(xiàn)遠程獲取路由與頁面刷新導(dǎo)致404錯誤的解決

    這篇文章主要介紹了Vue實現(xiàn)遠程獲取路由與頁面刷新導(dǎo)致404錯誤的解決,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • vue項目的屏幕自適應(yīng)多個方案總結(jié)

    vue項目的屏幕自適應(yīng)多個方案總結(jié)

    最近在用VUE寫大屏頁面,遇到屏幕自適應(yīng)問題,下面這篇文章主要給大家介紹了關(guān)于vue項目的屏幕自適應(yīng)多個方案的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • Nuxt的路由動畫效果案例

    Nuxt的路由動畫效果案例

    這篇文章主要介紹了Nuxt的路由動畫效果案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue.js 動態(tài)組件詳解

    vue.js 動態(tài)組件詳解

    這篇文章主要介紹了vue.js 動態(tài)組件詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09

最新評論