设为首页 加入收藏

TOP

手把手教你封装 Vue 组件并使用 NPM 发布(一)
2018-10-07 10:09:36 】 浏览:232
Tags:手把手 封装 Vue 组件 使用 NPM 发布

我们可以先查看Vue的插件的开发规范


我们开发的之后期望的结果是支持 import、require 或者直接使用 script 标签的形式引入,就像这样:
ps: 这里注意一下包的名字前缀是 unisoft ,组件的名字前缀是 uni


import UniSoftUI from 'unisoft-ui';
// 或者 const CustomUI = require('unisoft-ui');
// 或者 <script src="..."></script>
Vue.use(UniSoftUI); 


开发组件我们使用 webpack-simple 模板:


vue init webpack-simple <project-name>


目录结构如图:


开发单个组件:


先看一下目标效果:
ilvLWQ.gif


开始开发:
在 packages 文件夹下新建一个 switch 文件夹用来存放 switch 组件的源码,继续在 switch 文件夹中新建 uni-switch.vue 和 index.js 文件
uni-switch.vue 组件:


<template>
  <div class="uni-switch">
    <div class="wrapper">
      <span><slot></slot></span>
      <div :class="[{closed: !checked}, 'switch-box']"
          @click="handleChange(value)">
        <span :class="{closed: !checked}"></span>
      </div>


      <input
        type="checkbox"
        @change="handleChange"
        :true-value="activeva lue"
        :false-value="inactiveva lue"
        :disabled="disabled"
        :value="value"/>
    </div>
  </div>


</template>


<script>
  export default {
    name: "UniSwitch",
    data() {
      return {}
    },
    props: {
      value: {
        type: [Boolean, String, Number],
        default: false
      },
      activeva lue: {
        type: [Boolean, String, Number],
        default: true
      },
      inactiveva lue: {
        type: [Boolean, String, Number],
        default: false
      },
      disabled: {
        type: Boolean,
        default: false
      }
    },
    computed: {
      checked() {
        return this.value === this.activeva lue;
      }
    },
    methods: {
      handleChange(value) {
        this.$emit('input', !this.checked ? this.activeva lue : this.inactiveva lue);
      }
    }
  }
</script>


index.js:


//  UniSwitch 是对应组件的名字,要记得在 moor-switch.vue 文件中还是 name 属性哦
import UniSwitch from './UniSwitch.vue';
UniSwitch.install = Vue => Vue.component(UniSwitch.name, UniSwitch);
export default UniSwitch;


好了基本完成了,但是为了将所有的组件集中起来比如我还有 select、 input、 button 等组件,那么我想要统一将他们放在一个文件这中便于管理


所以在 App.vue 同级目录我新建了一个 index.js 文件


import UniSwitch from './packages/switch/index';
import UniSlider from './packages/slider/index';
import UniNumberGrow from './packages/number-grow/index';
import './common/scss/reset.css'
// ...如果还有的话继续添加


const components = [
  UniSwitch,
  UniSlider,
  UniNumberGrow
  // ...如果还有的话继续添加
]


const install = function (Vue, opts = {}) {
  components.map(comp

首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇在 Vuejs 项目中如何定义全局变量.. 下一篇Python数据图形化—— matplotlib..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目