规范 Rule

分类

  • 按照是否包含JS代码,Regular UI中的组件分为CSS组件JS组件
  • 按照NEC规范,Regular UI中的组件分为布局(Grid)元件(Unit)模块(Module)

命名规范

组件名、类名、对象名、标签名、CSS类名、JS文件名和CSS文件名必须保持一致性。

组件名和类名 对象名 标签名 CSS class  JS文件名 CSS文件名
大驼峰 小驼峰 小驼峰 小驼峰 小驼峰 小驼峰
- - <button> u-btn - btn.mcss
Modal modal <modal> m-modal modal.js modal.mcss
DetailModal detailModal <detailModal> m-detailModal detailModal.js detailModal.mcss
ListView listView <listView> m-listView listView.js listView.mcss
MusicListView musicListView <musicListView> m-musicListView musicListView.js musicListView.mcss
TreeView treeView <treeView> m-treeView treeView.js treeView.mcss
KnowledgeTreeView knowledgeTreeView <knowledgeTreeView> m-knowledgeTreeView knowledgeTreeView.js knowledgeTreeView.mcss
Calendar calendar <calendar> m-calendar calendar.js calendar.mcss
DatePicker datePicker <datePicker> u-datePicker datePicker.js datePicker.mcss
DateTimePicker dateTimePicker <dateTimePicker> u-dateTimePicker dateTimePicker.js dateTimePicker.mcss

CSS规范

Regular UI中所有组件的CSS样式都遵循NEC规范

补充

  • 为了防止组件内部class选择器的污染,并且为了好识别,使用_来做连字符。
    后代选择器的class定义为组件名+_+后代选择器的含义。
    如用:.m-tabs .tabs_hd, .m-calendar .calendar_hd,而不用:.m-tabs .hd, .m-calendar .hd
  • 为了防止组件内部语义化标签选择器的污染,使用>来进行限制选择。
    如用:.m-list>li,而不用:.m-list li
  • 对于简单的HTML结构尽量使用标签选择器而不使用class选择器。
    如用:.m-list>li, .m-crumb>li>a,而不用:.m-list .list_item, .m-crumb .crumb_a

MCSS/SCSS规范

变量命名

  • 变量的命名必须有意义,能够使人直接读懂变量的含义,如$brand-primary, $font-size-base, $u-radio_size等。
  • 主题的主要色系以$brand-开头,并在var.mcss文件中声明,如$brand-primary, $brand-info
  • 组件的公有变量以CSS属性名+特性,并在var.mcss文件中声明,如$font-size-base, $height-sm, $background-darker, ...
  • 组件的私有变量以class+'_'+属性名,仅在组件mcss文件中声明,如$u-radio_size, $m-tabs_hd_li_margin, ...
  • 常见状态:default, primary, info, success, warning, error, disabled, muted, ...
  • 大小分级:xxs, xs, sm, base, lg, xl, xxl, ...
  • 颜色分级:darkest, darker, dark, base, light, lighter, lightest, ...

强调

  • 尽量使用MASS库中的函数简化代码,如各种CSS3的前缀, $size, $line-height等。
  • HTML模板只用于表现组件的结构,因此不在模板标签中使用f-功能等样式,而用@extend方式在CSS中继承。
    如用:<div class="m-pager"> + .m-pager {@extend .f-wsn},而不用:<div class="m-pager f-wsn">
  • @extend方式只能继承自简单选择器。
  • 在可以用@extend的地方不使用mixin方式。

JS规范

补充

  • 组件中的私有方法开头加_,如:_onItemChange($event)_isCompleted()

Regular规范

组件声明

  • 每个组件必须在config中使用this.defaults显式声明默认数据。
  • 使用this.data,放弃使用Regular中configinit中传入的data参数。
  • 数据操作放在config中处理,DOM操作放在init中处理,并且尽量不进行DOM操作。

最佳实践:

let Modal = Component.extend({
    name: 'modal',
    template: template,
    /**
     * @protected
     * @override
     */
    config() {
        this.defaults({
            title: '提示',
            content: '',
            okButton: true,
            cancelButton: false,
            draggable: false
        });
        this.supr();
    },
    ...
    /* @public */
    ok() {...},
    /* @private */
    _onDragStart() {...},
    ...
});

强调

  • $update仅在以下两种情况中使用:
    • 组件内部异步回调函数中使用
    • 外部修改组件数据时使用
  • 在满足功能的前提下,尽量不使用$watch
  • 在不增加代码复杂度的前提下,尽量使用filtercomputed
  • directive仅用于简单的DOM操作,如:r-autofocus, r-scroll等,稍复杂的功能都使用组件来实现。

事件

  • 事件命名使用全部小写,并且不加on,如:change, dragend, itemselect, itemmouseup, ...
  • 与组件整体相关的事件,以动作或状态的形式命名,如change, dragend, ...
  • 与组件局部相关的事件,以对象+动作或状态的形式命名,如:itemselect, itemmouseup, ...
  • 与事件对应的处理方法采用小驼峰,并且加_on,如:_onDragEnd, _onItemSelect, _onItemMouseUp, ...
  • 事件参数必须为一个object对象,并且遵循以下形式:
{
    sender: this,    // 触发事件的发送对象,通常为this
    ...    // 其他相关参数
}

模板

  • 模板尽量采用HTML5风格,除了严格执行< />
    • 字符串加双引号
    • bool属性不加{true}{false}
    • 数字属性不加双引号
    • 表达式用{}且不加双引号
  • 每个组件都实现class扩展

最佳实践:

<progress percent=72 state="error" striped active />
<pager class="m-pager-custom" current=6 total=11 on-nav={this._onNav($event)} />

已使用的缩写

组件名

  • button => btn
  • image => img

class

  • head => hd
  • body => bd
  • foot => ft

状态名

  • active => act
  • disabled => dis
  • current => crt
  • selected => sel

扩展样式名

  • extra small => xs
  • small => sm
  • medium => md
  • large => lg
  • extra large => xl