最近在网上找到一个 网页制做辅助工具-jQuery标尺参考线插件 ,以为在如今的一个项目中能用的上,插件是基于JQuery的,可是如今的项目是用vue写的。So...,
就照葫芦画瓢改装成了Vue组件,总的来讲算是一个用处较多的组件,因而乎,就想着把它上传到Npm上分享出来。
之前只用过别人的包,这一次本身上传一个乐呵乐呵...顺便记录发布一下过程。
https://github.com/gorkys/vue...vue
这里用的是webpack-simple
,能够理解为精简版的vue-cli
webpack
vue init webpack-simple vue-ruler-tool
安装好后再就是一顿常规操做git
npm install npm dev
项目结构es6
原结构中红框里是放的vue的logo图片,用不着的东西,因此这里就把改为了组件文件夹与组件文件
还须要在src
下面新建一个index.js
做为入口文件,代码:github
// src/index.js export { default } from './components/vue-ruler-tool'
{ "name": "vue-ruler-tool", "description": "vue标尺辅助线", "version": "1.0.0", "author": "gorkys", "license": "MIT", // 开源协议 // 采用commonJs入口文件,若是不配置,咱们在其余项目中就不用import XX from XX来引用了,只能以包名做为起点来指定相对的路径 "main": "dist/index.js", "jsnext:main": "src/index.js", // 采用es6模块化入口 "private": false, // 由于组件包是公用的,因此private为false "scripts": { "dev": "cross-env NODE_ENV=development webpack-dev-server --open --hot", "build": "cross-env NODE_ENV=production webpack --progress --hide-modules" }, // 指定代码所在的仓库地址 "repository": { "type": "git", "url": "https://github.com/mauricius/vue-draggable-resizable.git" }, // 提交bug的地址 "bugs": { "url": "https://github.com/mauricius/vue-draggable-resizable/issues" }, // 项目官网的url "homepage": "https://github.com/mauricius/vue-draggable-resizable", "keywords": [ "vue", "component", "dragabble", "resizable" ], // 指定关键字 "dependencies": { "vue": "^2.5.11" }, "browserslist": [ "> 1%", "last 2 versions", "not ie <= 8" ], "devDependencies": { ... } }
由于要用dist文件夹,因此在.gitignore文件中把dist/去掉。
// 原 module.exports = { entry: './src/main.js', output: { path: path.resolve(__dirname, './dist'), publicPath: '/dist/', filename: 'build.js' } ... } // 新 module.exports = { entry: './src/index.js', output: { path: path.resolve(__dirname, './dist'), publicPath: '/dist/', filename: 'index.js', libraryTarget: 'umd', umdNamedDefine: true } ... }
npm run build npm pack
npm pack 以后,就会在当前目录下生成 一个vue-ruler-tool-1.0.0.tgz 的文件。
打开一个新的vue项目,将vue-ruler-tool-1.0.0.taz放到目录中,在当前路径下执行
npm install vue-ruler-tool-1.0.0.tgz
在新项目中引用组件就可使用了
在引用后报错没法解析,须要检查webpack.config.js
配置的输出文件路径是否与package.json
同样。web
进入官网,注册账号vue-cli
npm login npm publish
提示报错是由于注册完后没有进行邮箱验证,验证完成便可发布成功