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

一、总结

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

二、Web 组件开发规范Rules

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

Web 组件样式组织

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

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

    • variables.less
    • mixins.less
    • base.less
    • grid.less
    • block-grid.less
    • utility.less
  2. Amaze UI 其他样式组件:Web 组件编写过程中使用到类似的样式时应当引入相关 CSS 组件,在此上进行微调,比如 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 设置 <option> 数据
"dataList": [
{
"value": "false",
"title": "不启用",
"selected": true
},
{
"value": true,
"title": "启用"
}
]
}
}, // 内容
"content": {
// 内容类型 Array 数组、Object(对象)
"type": "Array",
"item": {
"title": {
"type": "text",
"comment": "面板标题"
},
"content": {
"type": "html",
"comment": "面板内容"
}
}
} // 表单接口 - 测试接口,细节还会做调整
// 提供的表单接口必须支持跨域调用,并返回 JSON 数据
"forms": {
"signin": {
"url": "http://api.xxx.com/signin", // 提交数据的接口
"type": "POST",
"desc": "登录表单,你可以在这里写表单的描述信息",
"fields": { // 表单字段,字段名称应该和返回数据里的字段对应
"username": {
"name": "用户名",
"placeholder": "请使用邮箱",
"type": "text",
"default": "",
"required": true
},
"password": {
"name": "密码",
"placeholder": "设置密码",
"type": "text",
"default": "",
"required": true
},
"submit": {
"name": "提交信息",
"type": "submit",
"default": ""
}
}
}, "signup": {
"url": "http://api.xxx.com/signup",
"type": "POST",
"desc": "注册表单,你可以在这里写表单的描述信息",
"fields": {
"username": {
"name": "用户名",
"placeholder": "请使用邮箱",
"type": "text",
"default": "",
"required": true
},
"password": {
"name": "密码",
"placeholder": "设置密码",
"type": "text",
"default": "",
"required": true
}
}
}
}
}, // 是否隐藏组件 - 此选项供云适配 WebIDE 使用
"hidden": false
}

README.md

Web 组件使用说明,包括 Web 组件 API 介绍、使用技巧、注意事项等。

HISTORY.md

Web 组件更新历史记录。

src 目录

src 目录包含 Web 组件的模板(hbs)、核心样式(less)、交互(js)、图标(png)、主题文件

src 目录里的文件使用 Web 组件名称作为文件名,主题使用 {Web 组件名}.{主题名}.less 形式命名。

  • {widget}.hbs: 模板,使用 handlebars
  • {widget}.less: 主题核心样式,使用 less 编写
  • {widget}.js: 组件交互
  • {widget}.png: 组件图标,50px * 50px
  • {widget}.default.less: 默认主题
  • {widget}.xxx.less: 其他主题,可以任意多

模板 {widget}.hbs

  • data-am-widget="figure" 为统一标识符
  • .am-{Web 组件名} 为 Web 组件基础标识符,Web 组件的所有子元素、主题、状态基于此命名; Web 组件基础标识符采用 am-{widget} 方式命名,子元素、主题、状态采用 am-{widget}-{子元素|主题|状态},如 am-figure-hover 、 am-figure-bd 、 am-figure-active 、 am-figure-ios7
  • 模板使用 {{#this}}..{{this}} 包裹(Web 组件使用时注册为 Handlebars partial,通过 {{> widget data}} 的形式调用。
 Copy
{{#this}}
<figure data-am-widget="figure"
class="am-figure{{#if theme}} am-figure-{{theme}}{{else}} am-figure-default{{/if}}{{#if options.zoomble}} am-figure-zoomable{{/if}}{{#if widgetId}} {{widgetId}}{{/if}}{{#if className}} {{className}}{{/if}}"{{#if id}}
id="{{id}}"{{/if}}>
{{#if content.img}}
<img src="{{content.img}}" alt="{{#if content.imgAlt}}{{content.imgAlt}}{{else}}{{content.figcaption}}{{/if}}"/>
{{/if}} {{#if content.figcaption}}
<figcaption class="am-figure-capition">
{{content.figcaption}}
</figcaption>
{{/if}}
</figure>
{{/this}}

注意:

  • Handlebars 模板中不支持 <script> 标签,如需加载外部脚本需在 {widget}.js 中进行。
  • 如果需要保存用户设置的选项,使用 data-am-{widget}-{option} 保存在模板中,然后在 {widget}.js 中通过 attr('data-am-{widget}-{option}') 读取。

核心样式 {widget}.less

Web 组件样式使用 less 编写。

 Copy
.am-{widget} {

  .hook-am-{widget};
} .hook-am-{widget}() {}

样式添加必要的 hook,方便用户修改。

默认主题 {widget}.defalt.less

 Copy
.am-{widget}-default {

  .hook-am-{widget}-default;
} .hook-am-{widget}-default() {}

其他主题 {widget}.xxx.less

 Copy
.am-{widget}-xxx {

  .hook-am-{widget}-xxx;
} .hook-am-{widget}-xxx() {}

Web 组件交互 {widget}.js

Amaze UI 使用 Seajs 、Zepto,Widget 的脚本需按照 Seajs 规范编写。

如果要在 JS 中动态插入外部样式、脚本,必须在 load 事件触发以后再执行相关操作,以免影响网页基本内容载入。

 Copy
define(function(require, exports, module) {
// 按此方式使用 Zepto
var $ = window.Zepto; });

开发脚手架

我们提供一个基于 Slush.js 的开发脚手架可以快速生成 Web 组件目录及相关文件

全局安装 Slush:

 Copy
npm install -g slush

全局安装 slush-amuiwidget:

 Copy
npm install -g slush-amuiwidget

在 Amaze UI 项目根目录下面执行:

 Copy
slush amuiwidget

调试预览

按照规范开发完 Web 组件以后,可以在本地调试预览组件。

在 Amaze UI 项目根目录下执行以下命令,安装依赖:

npm install

全局安装 nodemon

npm install nodemon -g

安装完成以后执行:

gulp preview

然后在浏览器里打开 http://localhost:3008/#{component} 查看组件的效果,{component} 替换为组件名称。

有样式、脚本、配置文件修改时,修改完成以后刷新浏览器即可,nodemon 会自动重启 Node 服务。

amazeui学习笔记二(进阶开发5)--Web 组件开发规范Rules的更多相关文章

  1. amazeui学习笔记二(进阶开发2)--Web组件简介Web Component

    amazeui学习笔记二(进阶开发2)--Web组件简介Web Component 一.总结 1.amaze ui:amaze ui是一个web 组件, 由模板(hbs).样式(LESS).交互(JS ...

  2. amazeui学习笔记二(进阶开发1)--项目结构structure

    amazeui学习笔记二(进阶开发1)--项目结构structure 一.总结 1.项目结构:是说的amazeui在github上面的项目结构,二次开发amazeui用 二.项目结构structure ...

  3. amazeui学习笔记二(进阶开发4)--JavaScript规范Rules

    amazeui学习笔记二(进阶开发4)--JavaScript规范Rules 一.总结 1.注释规范总原则: As short as possible(如无必要,勿增注释):尽量提高代码本身的清晰性. ...

  4. amazeui学习笔记二(进阶开发3)--HTML/CSS规范Rules

    amazeui学习笔记二(进阶开发3)--HTML/CSS规范Rules 一.总结 1.am:以 am 为命名空间 2.模块状态: {命名空间}-{模块名}-{状态描述} 3.子模块: {命名空间}- ...

  5. [Firefly引擎][学习笔记二][已完结]卡牌游戏开发模型的设计

    源地址:http://bbs.9miao.com/thread-44603-1-1.html 在此补充一下Socket的验证机制:socket登陆验证.会采用session会话超时的机制做心跳接口验证 ...

  6. 【音乐App】—— Vue-music 项目学习笔记:播放器内置组件开发(二)

    前言:以下内容均为学习慕课网高级实战课程的实践爬坑笔记. 项目github地址:https://github.com/66Web/ljq_vue_music,欢迎Star. 播放模式切换 歌词滚动显示 ...

  7. 【opencv学习笔记二】opencv3.4.0组件结构说明

    在学习opencv使用之前我们先来看一下opencv有哪些组件结构.至于OpenCV组件结构的研究方法, 我们不妨管中窥豹,通过opencv安装路径下include目录里面头文件的分类存放,来一窥Op ...

  8. amazeui学习笔记一(开始使用4)--Web App 相关

    amazeui学习笔记一(开始使用4)--Web App 相关 一.总结 1.桌面图标(Touch icon)解决方案:终极方案:link标签的rel和href属性: <link rel=&qu ...

  9. amazeui学习笔记一(开始使用1)--主干

    amazeui学习笔记一(开始使用1)--主干 一.总结 1.英语:学好英语,编程轻松很多 2. layouts compatibility change log web app collection ...

随机推荐

  1. HIVE JOIN_1

    HIVE JOIN 概述 Hive join的实现包含了: Common (Reduce-side) Join Broadcast (Map-side) Join Bucket Map Join So ...

  2. Windows10 Linux子系统的启用和中文用户名的修改

    一直用的虚拟机Linux,忽然心血来潮,看到Windows 10可以使用Linux子系统,于是来装一波,按照这位前辈的教程 https://blog.csdn.net/zhangdongren/art ...

  3. Mysql学习总结(7)——MySql索引原理与使用大全

    一.索引介绍 索引是对数据库表中一列或多列的值进行排序的一种结构.在关系数据库中,索引是一种与表有关的数据库结构,它可以使对应于表的SQL语句执行得更快.索引的作用相当于图书的目录,可以根据目录中的页 ...

  4. 安装Apache PHP MySQL PHPMyAdmin

    视频教程:https://www.youtube.com/watch?v=FJC2iGt_2bc,Youtube看不了的FQ吧-3- 本人参考这篇文章:http://blog.csdn.net/kno ...

  5. 【VC编程技巧】窗口☞3.4利用bitmap改变对话框的背景。

    效果图: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2hlbl9qaW50/font/5a6L5L2T/fontsize/400/fill/I0JBQ ...

  6. eclipse部署maven web项目到tomcat服务器时,没有将lib、web.xml复制过去的解决办法

    我这几天在写项目的时候发现自己以前的项目能够访问,隔一段时间写的这个项目却不能够访问,没有发现代码的逻辑错,但是就是访问不了jsp页面,项目一发布就是出现404错误,后来发现原来是发布到tomcat上 ...

  7. TCP连接状态详解

    tcp状态: LISTEN:侦听来自远方的TCP端口的连接请求 SYN-SENT:再发送连接请求后等待匹配的连接请求 SYN-RECEIVED:再收到和发送一个连接请求后等待对方对连接请求的确认 ES ...

  8. ElasticSearch概述和定义

    福利 => 每天都推送 欢迎大家,关注微信扫码并加入我的4个微信公众号:   大数据躺过的坑      Java从入门到架构师      人工智能躺过的坑         Java全栈大联盟   ...

  9. CF 843 A. Sorting by Subsequences

    A. Sorting by Subsequences You are given a sequence a1, a2, ..., an consisting of different integers ...

  10. AIX查看HBA卡的WWN号

    1,获得AIX主机连接的光纤设备:        # lsdev -Cc adapter -S a | grep fcs         fcs0      Available 09-08 FC Ad ...