npm 发布 vue 组件
创建 vue 组件
1、创建vue项目,为了简洁方便,推荐使用webpack-simple构建一个项目
vue init webpack-simple your-project
2、在 src 目录下新建子目录lib,用来放后面自己写的所有组件
3、编写自己的组件
首先新建一个vue文件和一个index.js
vue用于编写组件的模版和逻辑,像平时封装插件一样
ps:需要给组件命名 name: xxx
,用于后面的导出
具体如下:
index.js
作用是将该组件作为 Vue 插件,注册到 Vue 中
/** index.js **/
import xTable from './x-table.vue';
xTable.install = Vue => Vue.component(xTable.name, xTable);//.name就是开始说的vue文件暴露出来的name名,ldcPagination整个组件
export default xTable
4、最后集中管理,全部导出,可同时编写多个组件组成组件库,一起导出
在App.vue
同级目录我新建了一个index.js
文件
// 导入所有组件
import xTable from './table/index.js'
import xTableCol from './table-column/index.js'
const components = [xTable, xTableCol, hello]
const install = function(vue) {
/* istanbul ignore if */
if (install.installed) return;
/*eslint-disable*/
components.map((component) => {
vue.component(component.name, component); //component.name 此处使用到组件vue文件中的 name 属性
});
};
/* istanbul ignore if */
if (typeof window !== 'undefined' && window.Vue) {
install(window.Vue);
};
export default {
install,
xTable,
xTableCol
}
ps:如果是单个组件也可以不用编写第3中的与组件vue文件同级的index.js
,直接在这里import引入,然后导出
5、修改配置文件
打包之前,首先我们需要改一下 webpack.config.js 这个文件
// ... 此处省略代码
// 执行环境
const NODE_ENV = process.env.NODE_ENV
module.exports = {
// 改变入口
entry: './src/lib/index.js',
output: {
// 修改打包出口,在最外级目录打包出一个 index.js 文件,我们 import 默认会指向这个文件
path: path.resolve(__dirname, './dist'),
publicPath: '/dist/',
filename: "x-vue-element-table.min.js",
library: "xEleTable", // 指定的就是你使用require时的模块名
libraryTarget: 'umd', // libraryTarget会生成不同umd的代码,可以只是commonjs标准的,也可以是指amd标准的,也可以只是通过script标签引入的
umdNamedDefine: true // 会对 UMD 的构建过程中的 AMD 模块进行命名。否则就使用匿名的 define
},
// ... 此处省略代码
}
修改 package.json 文件(主要):
// ... 此处省略代码
// 发布开源因此需要将这个字段改为 false
"private": false,
// 这个指 import xEleTable 的时候它会去检索的路径
"main": "dist/vue-element-table.min.js",
// ... 此处省略代码
还有其他可配置项(非必须)
"bugs": {
"url": "https://github.com/xxx/xxx/issues"
},
"repository": {
"type": "git",
"url": "git@https://github.com/xxx/xxx.git"
},
5、测试,测试这些配置是否OK以及组件是否能够正常运行
首先通过命令npm run build
打包,打包完成后产生dist
文件,这个打包之后的文件的文件名是在webpack.config.js
接着执行命令npm pack
,会产生一个压缩包,在与webpack.config.js同一级目录
然后可以本地新建一项目测试是否可用
在测试项目中,通过npm install 组件项目打包后的本地绝对路径/文件全名
添加依赖
在main.js入口文件引入即可
import 名称 from ‘组件库名’
Vue.use(名称);
具体可参考
import xEleTable from 'x-vue-element-table'
Vue.use(xEleTable)
然后在项目的任意组件中引用就行了,如果引入成功,则说明打包成功,然后在发布
发布到 npm
准备工作OK,现在开始正式发布
//首先去npm官网注册一个npm账号
npm login // 登陆你的用户,密码
npm publish // 进行发布
在这个过程中,可能会出些问题
如果遇到以下这个错误
npm ERR! You do not have permission to publish "nodenpm". Are you logged in as the correct user? : nodenpm
【原因】可能是自己的组件名与npm中已有的组件名冲突,需要换成另一个还未被使用过的
另外提供几个常见错误解决方案(来自网络,有些自己遇到过~)
npm adduser报错Unable to authenticate?
npm publish项目报错
ps:遇到其他具体问题可自行百度解决~
ps:本文首发于我的segmentfault npm 发布 vue 组件
参考:
https://blog.csdn.net/qq_40513881/article/details/82494958
https://juejin.im/post/5b45df255188251b1d474860
https://blog.csdn.net/cscscssjsp/article/details/82501745
https://blog.suzper.com/2017/10/13/发布自己的vue组件库/
npm 发布 vue 组件的更多相关文章
- npm发布vue组件流程
初始化项目vue init webpack-simple XXX 定义组件略 发布配置1.package.json 2.webpack.config.js(注释部分为原配置) 发布1.登录 2.发布n ...
- 从零开始开发一个vue组件打包并发布到npm (把vue组件打包成一个可以直接引用的js文件)
自己写的组件 有的也挺好的,为了方便以后用自己再用或者给别人用,把组件打包发布到npm是最好不过了,本次打包支持 支持正常的组件调用方式,也支持Vue.use, 也可以直接引用打包好的js文件, 配合 ...
- 手把手教你封装 Vue 组件并使用 NPM 发布
Vue 开发插件 我们可以先查看Vue的插件的开发规范 我们开发的之后期望的结果是支持 import.require 或者直接使用 script 标签的形式引入,就像这样: ps: 这里注意一下包的名 ...
- 手把手教你封装 Vue 组件,并使用 npm 发布
Vue 开发插件 开发之前先看看官网的 开发规范 我们开发的之后期望的结果是支持 import.require 或者直接使用 script 标签的形式引入,就像这样: // 这里注意一下包的名字前缀是 ...
- 将 Vue 组件库发布到 npm
制作了一套自己的组件库,并发布到npm上,项目代码见 GitHub . 前期准备 有一个npm账号 安装了vue-cli 搭建项目 vue init webpack hg-vcomponents cd ...
- 基于vue组件,发布npm包
亲测好用,如出错,请留言 1.项目初始化 使用vue脚手架创建,但vuecli太重,我们使用简单的工程脚手架进行处理,输入命令 vue init webpack-simple my-project n ...
- 自定义Vue组件打包、发布到npm以及使用
本文将帮助:将自己写的Vue组件打包到npm进行代码托管,以及正常发布之后如何使用自己的组件. 本文讲述的仅仅是最基础的实现,其他复杂的操作需要非常熟悉webpack的相关知识,作者将继续学习. 先附 ...
- vue cli4构建基于typescript的vue组件并发布到npm
基于vue cli创建一个vue项目 首先安装最新的vue cli脚手架, npm install --global @vue/cli npm WARN optional SKIPPING OPTIO ...
- 如何从0开发一个Vue组件库并发布到npm
1.新建文件夹在终端打开执行 npm init -y 生成package.json如下,注意如果要发布到npm,name不能有下划线,大写字母等 { "name": "v ...
随机推荐
- java删除文件夹或者文件
private static void deleteFile(File file) { if (file.exists()) { // 判断文件是否存在 if (file.isFile()) { // ...
- 代码实现:编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函数1/1+1/3+...+1/n
import java.util.Scanner; //编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函数1/1+1/3+...+1/n public ...
- JAVA初级面试题,附个人理解答案
一,面向对象的特征:1.抽象 包括数据抽象跟行为抽象,将对象共同的特征取出形成一个类2.继承 被继承类为基类/超类,继承类为子类/派生类3.封装 多次使用道德数据或方法,封装成类,方便多次重复调用4. ...
- nodejs之express中间件body-parser使用
1.安装express和body-parser npm install express npm install body-parser 2‘.案例如下 var express = require('e ...
- Java学习之==>集合体系(待续。。)
一.概述 Java的集合体系,本质上是一个陈放数据的容器,像之前学过的数组也是陈放数据的容器,但在 Java 中数组的长度是固定的,使用起来没那么方便.集合提供了更加强大的功能,使用起来也更方便和快捷 ...
- python操作oracl数据库
#查询交易系统数据,判断当日是否有港股交易 import cx_Oracleimport os conn = Nonecursor = None hkfile = 'hk.txt'nohkfile = ...
- git 新建项目提交本地项目代码
git init git remote add origin ssh://git@42.123.127.93:10022/tyshawn/sdap1.git git add . git commit ...
- window10安装Elasticsearch及可视化工具es header
1.下载es(选择windows版本) https://www.elastic.co/cn/downloads/elasticsearch 2.解压安装包,到bin目录下,运行elasticsearc ...
- GitHub高级搜索
GitHub是开发目前最为活跃的开源网站和代码托管地,虽然我们经常使用GitHub,关注各种开源项目,但可能有很多人并不太了解GitHub的搜索功能的使用.GitHub提供了简单搜索和高级搜索,高级 ...
- 【Linux 驱动】简单字符设备驱动架构(LED驱动)
本文基于icool210开发板,内核版本:linux2.6.35: 驱动代码: (1)头文件:led.h #ifndef __LED_H__ #define __LED_H__ #define LED ...