开发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中

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,188评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,464评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,562评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,893评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,917评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,708评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,430评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,342评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,801评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,976评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,115评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,804评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,458评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,008评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,135评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,365评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,055评论 2 355

推荐阅读更多精彩内容

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