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

本文共 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://btmya.baihongyu.com/

你可能感兴趣的文章
JSONP实现跨域
查看>>
虚拟机VMware 9安装苹果MAC OSX 10.8图文教程
查看>>
微信小程序开发-框架
查看>>
redo、undo、binlog的区别
查看>>
DropDownList 控制日期控件显示格式
查看>>
RecycleView设置顶部分割线(记录一个坑)
查看>>
汉字转拼音 (转)
查看>>
Machine Learning Techniques -6-Support Vector Regression
查看>>
会计基础_001
查看>>
ajax请求拿到多条数据拼接显示在页面中
查看>>
小程序: 查看正在写的页面
查看>>
Jenkins持续集成环境部署
查看>>
检查磁盘利用率并且定期发送告警邮件
查看>>
MWeb 1.4 新功能介绍二:静态博客功能增强
查看>>
摄像机与绕任意轴旋转
查看>>
rsync 服务器配置过程
查看>>
预处理、const与sizeof相关面试题
查看>>
爬虫豆瓣top250项目-开发文档
查看>>
Elasticsearch增删改查
查看>>
oracle归档日志增长过快处理方法
查看>>