amazeui学习笔记二(进阶开发5)--Web 组件开发规范Rules
一、总结
1、见名知意:见那些class名字知意,见函数名知意,见文件名知意 例如(HISTORY.md
Web 组件更新历史记录。)
二、Web 组件开发规范Rules
目录
Web 组件基于 Amaze UI 基础库( / )开发,在基础库已有样式、功能的基础上做更多扩展。
Web 组件样式组织
Web 组件的样式有三个层级:
-
Amaze UI 基础样式: 每个网站项目中都会默认引入以下基础样式,组件开发时应在以下样式的基础上进行。
variables.less
mixins.less
base.less
grid.less
block-grid.less
utility.less
-
Amaze UI 其他样式组件:Web 组件编写过程中使用到类似的样式时应当引入相关 ,在此上进行微调,比如
button.less
、close.less
。 -
Web 组件自身样式:Web 组件自身样式拆分出骨干样式和主题样式;每个 Web 组件可以有多个不同主题,主题基于骨干样式编写,每个主题相互独立。
- 骨干样式以
{widget}.less
命名; - 默认主题以
{widget}.default.less
命名; - 其他主题以
{widget}.{theme-name}.less
命名。
- 骨干样式以
目录结构及说明
一个组件的目录结构如下:
{widget}|-- package.json|-- README.md|-- HISTORY.md|-- resources| `-- screenshots| |-- 0.jpg| |-- 1.jpg| `-- 2.jpg`-- src |-- {widget}.hbs |-- {widget}.js |-- {widget}.less |-- {widget}.default.less |-- {widget}.[theme1].less |-- {widget}.[themen].less `-- {widget}.png
package.json
Web 组件核心描述文件,json
格式,下面的注释仅为方便解释各项含义添加。
{ // 组件名称: 使用小写字母,不能和存在的组件重名 "name": "sample", // 版本号 "version": "0.0.1", // 组件本地化名字,目前有中文、英文两个选项 "localName": { "en": "", "zh-cn": "" }, // 组件类型 [""|"layout"|"social"] "type": "", // 组件 ICON,存放在 src 目录下 "icon": "sample.png", // 作者信息 "author": { "name": "xxx", "email": "xxx@yunshipei.com" }, // 组件描述 "description": "sample 描述", // 组件驱动者 "poweredBy": "AllMobilize", // 基础样式(无需修改) "styleBase": [ "variables.less", "mixins.less", "base.less", "grid.less", "block-grid.less", "utility.less" ], // 组件模板,使用 [handlebarsjs](http://handlebarsjs.com/) "template": "sample.hbs", // 依赖的库样式 "styleDependencies": [ "icon.less" ], // 组件核心样式 "style": "sample.less", // 组件主题(没有主题时将值设置为 null) "themes": [ { // 主题名称 sample.{xxx}.less 中的 {xxx},尽量语义化描述主题 "name": "default", // 主题描述,简要描述主题 "desc": "默认", // 主题使用配置选项 "options": {}, // 主题钩子 "hook": "hook-am-sample-default", // 主题使用的less变量 "variables": [ { // 变量名 "variable": "", // 变量描述名字 "name": "", // 默认值 "default": "", // 使用改变量的 css 样式 "used": [ { "selector": "", "property": "" } ] } ], // 主题演示数据,可以为多个 "demos": [ { // 演示描述 "desc": "", // 演示数据 "data": {} } ] } ], // Amaze UI 核心js(无需修改) "jsBase": [ "core.js" ], // 依赖的 Amaze UI js 插件 "jsDependencies": [], // 组件脚本 "script": "sample.js", // api 用于生成用户 GUI 界面以及保存用户提交的数据 "api": { "id": { "name": "ID", // 表单提示名称 "desc": "组件自定义ID,遵循CSS ID命名规范", "type": "text", // 表单类型 "default": "", // 默认值 "pattern": "", // 表单验证正则表达式 "required": false // 是否为必填 }, "className": { "name": "Class", "desc": "用户自定义组件 class,遵循 CSS class 命名规范", "type": "text", "default": "", "required": false }, // 主题选择(没有主题时将值设置为 null) "theme": { "name": "主题", "desc": "组件主题", "type": "select", // 下拉选框 "default": "default", "required": true, "dataList": "<%= pkg.themes %>" // 从 themes 中读取主题列表 }, // 组件选项(没有选项时将值设置为 null) "options": { "multiple": { "name": "同时展开多个面板", "desc": "是否允许同时展开多个面板", "type": "select", "default": false, "required": false, // 表单类型为 select 时通过 dataList 设置