好久没做独立的 vue 组件了,最近突然想把一个常用的 vue 组件打成一个 npm 包,方便使用。好久不用,发现已经忘记环境怎么搭建。翻看以前的组件,才慢慢回想起来,中间还出现些错误。在这记录下开发过程,以备忘。

一、新建工程

打成 npm 包的 vue 组件一般不会太复杂,当然如果是做一个 UI 库( 如:element-ui ),那另说。这里使用 vue-cli官方提供的 webpack-simple 模板来创建工程

  1. vue init webpack-simple <project-name>

二、初始化工程,安装相关依赖

  1. yarn install

三、创建组件相关目录

1、src 目录下新建 lib 文件夹,用来放置组件相关的文件。

2、在 lib 下新建 index.js 文件,用来导出组件。index.js 内容如下:

  1. import Demo from './demo.vue'
  2.  
  3. const demo = {
  4. install (Vue) {
  5. Vue.component(Demo.name, Demo)
  6. }
  7. }
  8. // IIFE
  9. if (typeof window !== 'undefined' && window.Vue) {
  10. window.Vue.use(demo)
  11. }
  12. export default demo

3、在 lib 下新建 demo.vue 文件,作为组件入口文件。demo.vue  内容如下:

  1. <template>
  2. <!--
  3. 组件 html 结构
  4. -->
  5. </template>
  6.  
  7. <script>
  8.  
  9. export default {
  10. name: "Demo",
  11. props: {
  12.  
  13. },
  14. data() {
  15. return {
  16.  
  17. };
  18. },
  19. mounted() {
  20.  
  21. },
  22. methods: {
  23. }
  24. };
  25. </script>
  26.  
  27. <style scoped>
  28.  
  29. </style>

三、修改 webpack.config.js,进行编译相关配置

  1. const path = require('path')
  2. const webpack = require('webpack')
  3. const ENV = process.env.NODE_ENV.trim()
  4. const pJson = require('./package.json')
  5.  
  6. module.exports = {
  7. // 入口,区分 ENV 环境变量
  8. entry: ENV==='production' ?'./src/lib/index.js':'./src/main.js',
  9. // 输出
  10. output: ENV==='production' ?
  11. {
  12. path: path.resolve(__dirname, './dist'),
  13. publicPath: '/dist/',
  14. filename: pJson.name + '.js',
  15. library: pJson.name,
  16. libraryTarget: 'umd',
  17. umdNamedDefine: true
  18. }:{
  19. path: path.resolve(__dirname, './dist'),
  20. publicPath: '/dist/',
  21. filename: 'build.js'
  22. },
  23. module: {
  24. rules: [
  25. {
  26. test: /\.css$/,
  27. use: [
  28. 'vue-style-loader',
  29. 'css-loader'
  30. ],
  31. },
  32. {
  33. test: /\.vue$/,
  34. loader: 'vue-loader',
  35. options: {
  36. loaders: {
  37. }
  38. // other vue-loader options go here
  39. }
  40. },
  41. {
  42. test: /\.js$/,
  43. loader: 'babel-loader',
  44. exclude: /node_modules/
  45. },
  46. {
  47. test: /\.(png|jpg|gif|svg)$/,
  48. loader: 'file-loader',
  49. options: {
  50. name: '[name].[ext]?[hash]'
  51. }
  52. }
  53. ]
  54. },
  55. resolve: {
  56. alias: {
  57. 'vue$': 'vue/dist/vue.esm.js'
  58. },
  59. extensions: ['*', '.js', '.vue', '.json']
  60. },
  61. devServer: {
  62. historyApiFallback: true,
  63. noInfo: true,
  64. overlay: true
  65. },
  66. performance: {
  67. hints: false
  68. },
  69. devtool: '#eval-source-map'
  70.  
  71. }
  72.  
  73. if (process.env.NODE_ENV === 'production') {
  74. module.exports.devtool = '#source-map'
  75. module.exports.plugins = (module.exports.plugins || []).concat([
  76. new webpack.DefinePlugin({
  77. 'process.env': {
  78. NODE_ENV: '"production"'
  79. }
  80. }),
  81. // source-map 配置,区分 ENV 环境变量
  82. new webpack.optimize.UglifyJsPlugin({
  83. sourceMap: ENV==='production' ? false : true,
  84. compress: {
  85. warnings: false
  86. }
  87. }),
  88. new webpack.LoaderOptionsPlugin({
  89. minimize: true
  90. })
  91. ])
  92. }

四、组件效果预览

1、修改 src/main.js 导入组件

  1. import Demo from './lib/index.js'
  2. Vue.use(Demo)

2、修改 src/App.vue 使用组件

  1. <template>
  2. <div id="app">
  3. <Demo/>
  4. </div>
  5. </template>

3、运行 ,浏览器预览效果

  1. yarn run dev

五、发布

1、修改  package.json

  1. "name": "demo",
  2. "main": "dist/demo.js",
  3. "private": false,

2、修改 .gitignore ,删除 dist 条目,如果不删除,提交时会忽略 dist 文件夹的内容,发布后 npm 安装使用时,会找不到文件,因为组件编译好的文件是放在  dist 目录下。

3、编写 README.md,介绍组件的功能

4、发布( 默认已有帐号,且已登录 )

  1. yarn run build
  2. npm config set registry=https://registry.npmjs.org
  3. npm publish

vue 组件发布记录的更多相关文章

  1. vue-cli3.0 vue组件发布到npm

    一.创建项目 1.vue create xxx (使用的版本是3.1.0) 2.把src目录名称改为examples 3.新建文件夹packages 用来存放组件 4.比如:新建Button组件 in ...

  2. krry-transfer ⏤ 基于 element 的升级版穿梭框组件发布到 npm 啦

    博客地址:https://ainyi.com/81 基于 element ui 的==升级版穿梭框组件==发布到 npm 啦 看过我之前博客的同学或许知道我之前写过关于 element 穿梭框组件重构 ...

  3. 手把手教你封装 Vue 组件并使用 NPM 发布

    Vue 开发插件 我们可以先查看Vue的插件的开发规范 我们开发的之后期望的结果是支持 import.require 或者直接使用 script 标签的形式引入,就像这样: ps: 这里注意一下包的名 ...

  4. 手把手教你封装 Vue 组件,并使用 npm 发布

    Vue 开发插件 开发之前先看看官网的 开发规范 我们开发的之后期望的结果是支持 import.require 或者直接使用 script 标签的形式引入,就像这样: // 这里注意一下包的名字前缀是 ...

  5. vue组件从开发到发布

    组件化是前端开发非常重要的一部分,从业务中解耦出来,可以提高项目的代码复用率.更重要的是我们还可以打包发布,俗话说集体的力量是伟大的,正因为有许许多多的开源贡献者,才有了现在的世界. 不想造轮子的工程 ...

  6. 将 Vue 组件库发布到 npm

    制作了一套自己的组件库,并发布到npm上,项目代码见 GitHub . 前期准备 有一个npm账号 安装了vue-cli 搭建项目 vue init webpack hg-vcomponents cd ...

  7. 自己编写并发布一个Vue组件

    自己编写并发布一个Vue组件 1. 几种开源协议的介绍 https://blog.csdn.net/techbirds_bao/article/details/8785413 2.开始编写组件 新建p ...

  8. 基于vue组件,发布npm包

    亲测好用,如出错,请留言 1.项目初始化 使用vue脚手架创建,但vuecli太重,我们使用简单的工程脚手架进行处理,输入命令 vue init webpack-simple my-project n ...

  9. 自定义Vue组件打包、发布到npm以及使用

    本文将帮助:将自己写的Vue组件打包到npm进行代码托管,以及正常发布之后如何使用自己的组件. 本文讲述的仅仅是最基础的实现,其他复杂的操作需要非常熟悉webpack的相关知识,作者将继续学习. 先附 ...

随机推荐

  1. I/O系统(一)

    输入输出系统的发展大致可以分为4个阶段1.早期阶段 特点:    1.1每个IO设备都得有一套独立的逻辑电路和CPU相连.    1.2输入输出过程需要通过CPU,穿插在程序运行的过程中,处理IO时候 ...

  2. GUI学习之〇——PyQt5安装

    GUI(Graphical User Interface)是程序和软件使用者的接口,好的GUI是一个良好的软件的前提,在这里演示一下用PyQt5做一个GUI的方法 软件需求:python3.6 用的是 ...

  3. trinitycore 魔兽服务器源码分析(一) 网络

    trinitycore是游戏服务器的开源代码 许多玩家使用魔兽的数据来进行测试 ,使用它来假设魔兽私服. 官方网址  https://www.trinitycore.org/ 类似的还有mangos ...

  4. 【APP测试(Android)】--安装卸载

  5. UVA 10534 Wavio Sequence

    题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=17&p ...

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

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

  7. 1.8 新特性之 Lambda Expressions

    Lambda expressions are allowed only at source level 1.8 or above The target type of this expression ...

  8. HTML之<meta>使用和说明

    关于<meta>,我们都不陌生,随意打开一个网页查看源代码就可以看到<head>里出现它的身影. 简单来说,<meta>是描述 HTML 文档的元数据.例如网页描述 ...

  9. (转载)linux 常用命令

    出处:http://www.cnblogs.com/vamei $ 命令行提示符 粗体表示命令 斜体表示参数 filename, file1, file2 都是文件名.有时文件名有后缀,比如file. ...

  10. spring boot开发笔记——mybatis

    概述   mybatis框架的优点,就不用多说了,今天这边干货主要讲mybatis的逆向工程,以及springboot的集成技巧,和分页的使用   因为在日常的开发中,当碰到特殊需求之类会手动写一下s ...