开发Vue UI库教程

做前端开发的朋友多少都有使用过一些UI库的经验,下面是如何参照element-ui开发一款属于自己的ui库 MS-UI的方法

element-ui的源码阅读起来很方便,作者参照它实现了一套自己的UI库,感觉受益良多

  • 使用vue-cli 创建你的项目工程
vue create ms-ui
  • 使用vue封装一些组件,并且把样式文件和组件的源码分开目录存放
// 组件
packages/buton/main.vue
packages/buton/index.js
// style
packages/theme/button.css
  • 国际化

原理是封装一个能提取翻译后内容的方法,通过mixin注入到实例中,在组件中使用该方法提取对应的翻译后内容

// lang/en.js
export default {
    ms: {
        colorpicker: {
            confirm: 'OK',
            clear: 'Clear'
        },
import defaultLang from './lang/zh-CN';
import Vue from 'vue';
import Format from './format';

const format = Format(Vue);
let lang = defaultLang;

export const t = function(path, options) {
    let value;

    const array = path.split('.');
    let current = lang;
    // console.log(current)
    // console.log(path, array)
    for (let i = 0, j = array.length; i < j; i++) {
        const property = array[i];
        value = current[property];
        if (i === j - 1) return format(value, options);
        if (!value) return '';
        current = value;
    }
    // console.log(value)
    return '';
};

export const use = function(l) {
    lang = l || lang;
}

export default { use, t };
//xxx.vue
<script>
import Locale from '../../mixins/locale'
import MsPopup from '../popup/main'
import MsButton from '../button/main'
import MsInput from '../input/main'
export default {
    name: 'MsMessageBox',
    mixins: [Locale],
    components: {MsPopup, MsInput, MsButton},
    data () {
        console.log(this.t('ms.messagebox.cancel'))
        return {
            visiblePopup: false,
            visible: false,
            showCancelBtn: false,
            cancelBtnText: this.t('ms.messagebox.cancel'),
...

  • 组件化
    使用babel-plugin-component实现,使用方式github上有文档
plugins: [
    [
      "component",
      {
        libraryName: "@shawbs/ms-ui", // npm包的名字
        styleLibraryName: "theme", // 引入模块对应的样式文件,如 import { button } '@shawbs/ms-ui',它会把lib/theme下同模块名的文件引入
        style: true
      }
    ]
  ]
  • 主题化
    配置样式变量,引入库的样式源文件
/* 改变主题色变量 */
$--color-primary: teal;

/* 改变 icon 字体路径变量,必需 */
$--font-path: '~@shawbs/ms-ui/lib/theme/font';
// 库的样式源文件
@import "~@shawbs/ms-ui/main/packages/theme/src/index";
  • 打包部署
    使用gulp + webpack的方式

gulp负责copy,编译scss
webpack 负责编译模块文件

  • 发布

注册npm帐号
shell登录npm
npm publish

  • 写文档

使用docsify生成文档网站,
github中创建github page项目,
把docsify中的源码push到你生成的github page中

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 元素会创建包含另外一个文档的内联框架(即行内框架); 一、align 属性(不赞成) align属性规定ifram...
    puxiaotaoc阅读 19,766评论 0 14
  • JavaScript 将字符串转换为数字 parseInt() ◆只保留数字的整数部分,不会进行四舍五入运算。 ...
    AkaTBS阅读 1,001评论 0 9
  • 网站优化离不开前后端的互相协作,但是对于前端工程师来说,在保证后端技术方案不变时,能不能只利用前端技术来优化网站呢...
    留七七阅读 6,382评论 0 31
  • 前端开发面试题 面试题目: 根据你的等级和职位的变化,入门级到专家级,广度和深度都会有所增加。 题目类型: 理论知...
    怡宝丶阅读 2,606评论 0 7
  • 春天,小草发芽,树木绿了,河水也解冻了。水哗哗的流着,听,像不像一首轻快的音乐呢?河里几条小鱼在游着嬉戏着 它...
    小菘籽阅读 942评论 0 2