博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
amazeui学习笔记二(进阶开发5)--Web 组件开发规范Rules
阅读量:6586 次
发布时间:2019-06-24

本文共 3911 字,大约阅读时间需要 13 分钟。

amazeui学习笔记二(进阶开发5)--Web 组件开发规范Rules

一、总结

1、见名知意见那些class名字知意,见函数名知意,见文件名知意 例如(HISTORY.md Web 组件更新历史记录。)

 

 

二、Web 组件开发规范Rules

目录

Web 组件基于 Amaze UI 基础库( / )开发,在基础库已有样式、功能的基础上做更多扩展。

Web 组件样式组织

Web 组件的样式有三个层级:

  1. Amaze UI 基础样式: 每个网站项目中都会默认引入以下基础样式,组件开发时应在以下样式的基础上进行。

    • variables.less
    • mixins.less
    • base.less
    • grid.less
    • block-grid.less
    • utility.less
  2. Amaze UI 其他样式组件:Web 组件编写过程中使用到类似的样式时应当引入相关 ,在此上进行微调,比如 button.lessclose.less

  3. 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 格式,下面的注释仅为方便解释各项含义添加。

 Copy
{    // 组件名称: 使用小写字母,不能和存在的组件重名    "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 设置 

转载地址:http://vihno.baihongyu.com/

你可能感兴趣的文章
重构-使代码更简洁优美:实际经验之谈(提供一技巧,让你省掉N多代码)
查看>>
C# 判断远程文件是否存在
查看>>
backbone学习笔记:集合(Collection)
查看>>
[C#基础]说说委托+=和-=的那些事
查看>>
SSH原理与运用(一):远程登录
查看>>
Spring Framework 4.2 中的新功能和增强功能
查看>>
动态代理解决网站字符集编码
查看>>
C#中Encoding.Unicode与Encoding.UTF8的区别
查看>>
Spring中的AOP(二)——AOP基本概念和Spring对AOP的支持
查看>>
MarkDown的使用
查看>>
图像处理------简单脸谱检测算法
查看>>
在新美大“创业”:KTV预定业务演进之路
查看>>
Swap in C C++ C# Java
查看>>
简单高效的云服务器单元化扩容方案
查看>>
ubuntu开机直接进入命令行模式
查看>>
重读《JavaScript DOM编程艺术》(第一版)
查看>>
Shell脚本监控CPU、内存和硬盘利用率
查看>>
任务记录:OEA 框架中的多类型树控件
查看>>
x264代码剖析(四):vs2010编译x264错误集锦
查看>>
SQL*Plus环境下创建PLUSTRACE角色
查看>>