前言:工作的时候总是使用别人的npm包,然而我有时心底会好奇自己如何发布一个npm包呢,什么时候自己的包能够被很多人喜欢并使用呢...今天我终于迈出了第一步。

前提:会使用 npm,有 vue 基础,了解一点 webpack

Are you ready?  Go!

目录

一、编写自己的npm包

  1. 新建一个空文件夹

  2. 进入文件夹,终端(cmd)运行 npm init

  

  完成后会在目录下生成一个 package.json 文件

  我们可以根据自己的需要补充文件内容

  这是我的:

  1. {
  2. "name": "bing-test-publish-npm",
  3. "version": "1.0.0",
  4. "description": "布一个npm包",
  5. "main": "index.js",
  6. "scripts": {
  7. "test": "echo \"Error: no test specified\" && exit 1",
  8. "start": "webpack-dev-server --hot --inline",
  9. "build": "webpack --display-error-details --config webpack.config.js"
  10. },
  11. "author": "bing",
  12. "license": "ISC",
  13. "devDependencies": {
  14. "babel-core": "^6.26.0",
  15. "babel-loader": "^7.1.2",
  16. "babel-plugin-transform-object-rest-spread": "^6.26.0",
  17. "babel-plugin-transform-runtime": "^6.23.0",
  18. "babel-polyfill": "^6.26.0",
  19. "babel-preset-es2015": "^6.24.1",
  20. "css-loader": "^0.28.7",
  21. "es6-promise": "^4.1.1",
  22. "less": "^2.7.3",
  23. "less-loader": "^4.0.5",
  24. "style-loader": "^0.19.0",
  25. "url-loader": "^0.6.2",
  26. "vue": "^2.5.9",
  27. "vue-hot-reload-api": "^2.2.4",
  28. "vue-html-loader": "^1.2.4",
  29. "vue-loader": "^13.5.0",
  30. "vue-router": "^3.0.1",
  31. "vue-style-loader": "^3.0.3",
  32. "vue-template-compiler": "^2.5.9",
  33. "vuex": "^3.0.1",
  34. "webpack": "^3.9.1",
  35. "webpack-dev-server": "^2.9.5"
  36. }
  37. }

  3. 配置完后,命令行运行 npm install 安装依赖包,安装完会生成一个node_modules目录

  4. 接下来新建两个文件夹 src(开发目录),dist(发布目录)

  5. 然后我们就可以在 src 目录下编写自己的组件吧

  我的文件目录

  

  app.vue

  1. <template>
  2. <div class="helloName">
  3. <input type="text" placeholder="请输入姓名" v-model="yourName"></input>
  4. <div v-if="name">hello<span class="name">{{name}}!</span></div>
  5. </div>
  6. </template>
  7. <script>
  8. export default {
  9. name:'helloName',
  10. data () {
  11. return {
  12. yourName: ''
  13. }
  14. },
  15. methods: {
  16.  
  17. },
  18. created(){
  19. }
  20. }
  21. </script>
  22. <style>
  23. </style>

  index.js

  1. import helloName from './app.vue'
  2. export default helloName

  webpack.dev.conf.js

  1. const path = require("path");
  2. const webpack = require("webpack");
  3. const uglify = require("uglifyjs-webpack-plugin");
  4.  
  5. module.exports = {
  6. devtool: 'source-map',
  7. entry: "./src/index.js",//入口文件,src目录下的index.js文件,
  8. output: {
  9. path: path.resolve(__dirname, './dist'),//输出路径,就是新建的dist目录,
  10. publicPath: '/dist/',
  11. filename: 'helloName.min.js',
  12. libraryTarget: 'umd',
  13. umdNamedDefine: true
  14. },
  15. module: {
  16. rules: [{
  17. test: /\.vue$/,
  18. loader: 'vue-loader'
  19. },
  20. {
  21. test: /\.less$/,
  22. use: [
  23. { loader: "style-loader" },
  24. { loader: "css-loader" },
  25. { loader: "less-loader" }
  26. ]
  27. },
  28. {
  29. test: /\.js$/,
  30. exclude: /node_modules|vue\/dist|vue-router\/|vue-loader\/|vue-hot-reload-api\//,
  31. loader: 'babel-loader'
  32. },
  33. {
  34. test: /\.(png|jpg|gif|ttf|svg|woff|eot)$/,
  35. loader: 'url-loader',
  36. query: {
  37. limit: ,
  38. name: '[name].[ext]?[hash]'
  39. }
  40. }
  41. ]
  42. },
  43. plugins: [
  44. new webpack.DefinePlugin({
  45. "process.env": {
  46. NODE_ENV: JSON.stringify("production")
  47. }
  48. })
  49. ]
  50. }

  文件写好后,我们运行 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

  如:

  1. .*
  2. *.md
  3. *.yml
  4. build/
  5. node_modules/
  6. src/
  7. test/
  8. gulpfile.js

二、发布npm包

  1. 到 https://www.npmjs.com 注册一个账号

  2. 进入你的项目根目录,运行 npm login

     会输入你的用户名、密码和邮箱

  3. 登录成功后,执行 npm publish,就发布成功啦,我们可以在官网看到

  

三、使用自己的npm包

  接下来我们在其他项目中使用自己刚发布的npm包

  1. 我们进入我们的项目目录运行 npm (或cnpm) install bing-test-publish-npm(我们刚发布的包)

  

  2. 在需要使用此包的页面引入,并使用

  1. <template>
  2. <div>
  3. 我的npm包
  4. <helloName></helloName>
  5. </div>
  6. </template>
  7. <script>
  8. import helloName from 'bing-test-publish-npm'
  9. export default {
  10. name: 'npm',
  11. data () {
  12. return {
  13. }
  14. },
  15. components: {
  16. helloName
  17. }
  18. }
  19. </script>

  这时我发现我的控制台报错了,原来是编码错误,因此,我们需要修改更新代码

  1. <template>
  2. <div class="helloName">
  3. <input type="text" placeholder="请输入姓名" v-model="yourName"></input>
  4. <div v-if="yourName">hello<span class="name">{{yourName}}!</span></div>
  5. </div>
  6. </template>
  7. <script>
  8. export default {
  9. name:'helloName',
  10. data () {
  11. return {
  12. yourName: ''
  13. }
  14. },
  15. methods: {
  16.  
  17. },
  18. created(){
  19. }
  20. }
  21. </script>
  22. <style>
  23. </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 uninstall bing-test-publish-npm

    重新安装 npm install bing-test-publish-npm

    可通过 npm list bing-test-publish-npm 查看到版本已是最新的版本

五、最终效果

  

主要参考文章

  1. 如何制作并发布一个vue的组件npm包? https://blog.csdn.net/hamupp/article/details/79337643

  2. package.json   http://javascript.ruanyifeng.com/nodejs/packagejson.html

~~~~~~~~~~~~~~~~~~~~~~~我是简朴又廉价的分割线~~~~~~~~~~~~~~

饼饼有话说:

写的好辛苦呀说实话这个编辑器不咋好用。。

花了好半天写文章,又花了一会修改文章格式,这次给自己认真程度打80分吧,想要写一篇优秀的博文好不容易呀,我会继续加油哒~~

如果觉得受用的话,可不可以给我点个赞呀,激励这个拖延症患者~~

如何发布一个npm包(基于vue)的更多相关文章

  1. 从0到1发布一个npm包

    从0到1发布一个npm包 author: @TiffanysBear 最近在项目业务中有遇到一些问题,一些通用的方法或者封装的模块在PC.WAP甚至是APP中都需要使用,但是对于业务的PC.WAP.A ...

  2. 发布一个npm包(webpack loader)

    发布一个npm包,webpack loader: reverse-color-loader,实现颜色反转. 初始化项目 mkdir reverse-color-loader cd ./reverse- ...

  3. (转)前端开发-发布一个NPM包之最简单易懂流程

    原文地址:https://www.cnblogs.com/sghy/p/6829747.html 1.npm官网创建npm账户 npm网站地址:https://www.npmjs.com/ npm网站 ...

  4. 如何发布一个npm包?

    npm包在现在前端开发中经常使用且便利,而我也是经常使用,而没研究怎么去发布npm.那如何发布npm包呢? 一.在npm的官网上注册一个账号登录,https://www.npmjs.com/ 注意此步 ...

  5. 如何发布一个 npm 包

    一 背景 在工作时,突然接到经理的一个要求,需要将一个react的高阶组件函数封装成一个npm包.之前从没弄过,当场还是有些懵逼的,但是这毕竟是工作,不能推脱.于是开始了学习.汤坑之旅.最终包发布,线 ...

  6. 发布一个npm包

    前言 我这里是写了一个vue轮播图插件,因此我使用了vue的脚手架工具创建一个项目,当然你也可以选择自己搭建脚手架. 本例中我会使用vue脚手架创建一个项目,并发布到npm上面去. 通过脚手架创建项目 ...

  7. webpack创建library及从零开始发布一个npm包

    最近公司有个需求,我们部门开发一个平台项目之后,其他兄弟部门开发出的插件我们可以拿来直接用,并且不需要我们再进行打包,只是做静态的文件引入,研究一波后发现,webpack创建library可以实现. ...

  8. 如何发布一个包到npm && 如何使用自己发布的npm包 && 如何更新发布到npm的package && 如何更新当前项目的包?

    如何发布一个包到npm First 在https://www.npmjs.com注册一个账号. Second 编辑好项目,文件大致如下: 其中,gitignore可以如下: .DS_Store nod ...

  9. 如何开发一个npm包并发布到npm中央仓库

    转自: https://liaolongdong.com/2019/01/24/publish-public-npm.html 如何开发一个npm包并发布到npm中央仓库需求背景:平时在项目工作中可能 ...

随机推荐

  1. centos 7 一些命令

    su 切换到管理员账户cd 'wo shi mu lu'ls 查看 当前目录或者文件tar -xvzf pip-10.0.1.tar.gz 解压 文件systemctl restart network ...

  2. 《JAVA程序设计》第四周总结

    第四周作业总结 学习内容: 1.根据教材视频学习第五章:子类和继承 2.调试代码和解决问题 3.上周错题 4.代码托管 知识总结 子类:在类的声明中,通过使用关键字extends来定义一个类的子类. ...

  3. docker容器的使用

    Docker客户端 docker客户端非常简单,我们可以直接输入docker命令来查看到Docker客户端的所有命令选项. runoob@ docker 可以通过命令docker command -- ...

  4. font-smoothing使用后字体看起来会更清晰舒服

    CSS3里面加入了一个“-webkit-font-smoothing”属性. 这个属性可以使页面上的字体抗锯齿,使用后字体看起来会更清晰舒服. 加上之后就顿时感觉页面小清晰了. 淘宝也在用哦! 它有三 ...

  5. python参数

    1.形参变量和实参 形参变量:只有在被调用时才分配内存单元,在调用结束时,即释放所分配的内存单元,因此,形参只在函数内有效,函数调用结束返回主调用函数后则不能再使用该形参变量. 实参:可以是常量,变量 ...

  6. Solidity合约记录——(三)如何在合约中对操作进行权限控制

    合约中一般会有多种针对不同数据的操作:例如对于存证内容的增加.更新及查询,若不进行一套符合要求的权限控制,事实上整个合约在真实环境下是没有多少使用价值的.那么应当如何对合约的权限进行划分?我们针对So ...

  7. 高效率php注意事项

    1.尽量静态化: 如果一个方法能被静态,那就声明它为静态的,速度可提高1/4,甚至我测试的时候,这个提高了近三倍. 当然了,这个测试方法需要在十万级以上次执行,效果才明显. 其实静态方法和非静态方法的 ...

  8. JavaScript基础视频教程总结(031-040章)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  9. javascript(作业九)

    1.javascript简介: JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型.它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端 ...

  10. Vuejs——(8)Vuejs组件的定义

    版权声明:出处http://blog.csdn.net/qq20004604   目录(?)[+]   本篇资料来于官方文档: http://cn.vuejs.org/guide/components ...