Skip to content

waterfly/vue-component-demo

Repository files navigation

[toc]

VueComponentDemo

Vue CLI创建Vue组件示例

创建步骤

下载Vue CLI,并创建工程

// 1.瞎子啊 vue/cli
npm install -g @vue/cli
or
yarn global add @vue/cli

// 2.使用Vue CLI创建工程
vue create vue-component-demo

// 或使用图形化创建
vue ui

修改目录结构

  • 修改scr目录为examples,用来做Demo
  • 增加 packages目录,存放组件源码

创建vue.config.js

添加以下配置支持packages目录编译

module.exports = {
  // 修改src目录为examples目录
  pages: {
    index: {
      entry: "examples/main.js",
      template: "public/index.html",
      filename: "index.html",
    },
  },
  // 扩展webpack配置,使packages加入编译
  chainWebpack: (config) => {
    config.module
      .rule("js")
      .include.add("/packages")
      .end()
      .use("babel")
      .loader("babel-loader")
      .tap((options) => options);
  },
  productionSourceMap: true,
};

packages目录下编写组件

添加组件HelloVueComponent.vueindex.js,在index.js里实现HelloVueComponent的install方法

import HelloVueComponent from "./HelloVueComponent.vue";

HelloVueComponent.install = function (Vue) {
  Vue.component(HelloVueComponent.name, HelloVueComponent);
};

export default HelloVueComponent;

增加打包命令

package.json文件里增加组件打包命令lib

"scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "lib": "vue-cli-service build --target lib --name vue-component-demo --dest lib packages/index.js",
    "lint": "vue-cli-service lint"
  },

配置json文件参数

package.json增加配置,增加以下字段:

  • description,库作用描述
  • keywords,关键字,用于搜索
  • license,证书
  • author,作者
  • repository,仓库说明
  • homepage,主页
  • main,组件库的主入口地址
// 示例
"description": "Vue组件Demo",
  "keywords": [
    "Vue",
    "组件",
    "Demo"
  ],
  "license": "ISC",
  "author": {
    "name": "waterFly",
    "email": "[email protected]"
  },
  "repository": {
    "type": "git",
    "url": "[email protected]:waterfly/vue-component-demo.git"
  },
  "homepage": "https://github.com/waterfly/vue-component-demo",
  "main": "lib/vue-component-demo.umd.min.js",

注:详见package.json文件字段解释

增加.npmignore文件

.npmignore用于过滤不需要发布的文件或文件夹。

doc/
examples/
packages/
public/
babel.config.js
vue.config.js

过滤文件有三种方式:

  1. 设置.gitignore文件,在gitnpm publish都会被过滤
  2. 设置.npmignore文件,在npm publish会被过滤
  3. 设置package.json文件的files字段,用来设置发布那些文件或目录

优先级: files > .npmignore > .gitignore

发布

注意移除package.json文件里 private字段

// 1. 编译
yarn lib

// 2. 登录
yarn login

// 3. 发布
yarn publish

附录

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published