平台组件升级改造方案

平台组件方案设计

方案背景

统一平台交互,提升用户体验,保障组件研发质量,组件稳定性,组件可维护性,在改善平台体验的同时,挖掘组件的亮点功能

方案目标

  • 统一的界面视觉效果
  • 统一的不同页面杂乱组件
  • 统一的交互规则
  • 基于组件已有功能对组件进行增强(功能,性能)
  • 组件场景拓展(基于业务场景拓展组件,挖掘场景价值)

平台当前现状

  • 平台组件不统一

    • 搜索条件未统一封装 人员选择器/ 时间/ 部门/ 项目/ 角色/ 组织架构树
    • 表格组件未统一封装
    • 弹框样式不统一
    • 系统消息通知样式普通,且不统一
    • 控件大小不统一,例如,按钮,输入框,
    • 统一树形目录控件场景
  • 样式不统一,不协调

    • 颜色体系混乱,不协调,不像大平台
    • 字体大小随意,没有打磨
    • 间距不统一,每个页面是有单独的设置
    • 圆角使用时机无规范
    • 阴影使用很随意
  • 交互不统一

    • 前期开发,交互上是按照开发自己发挥,后期需要进行总结,例如,目录树的操作,表格的右键操作,
    • 按钮请求时,需要显示loading,需要有防抖处理
  • 风格不确定

    • 是ones工业风,还是云效风格
  • 组件质量无法保障

    • 修改后,无法保证其他组件不受影响
    • 测试覆盖率低,需要总结使用场景
    • 组件要求文档不完善,组件开发需要有文档支撑
  • 规范不统一

    • 界面开发后,效果无法保障基本美观性,总需要再设计

方案设计

界面规范

基础规范

  1. 布局规范设计
  • 栅格系统(24列)
  • 响应式断点
  • 组件间距(8px倍数)
  • 内容对齐方式
  1. 加载状态
  • 页面首次加载时显示骨架屏
  • 局部数据加载时显示loading动画
  • 提供加载超时处理机制

样式规范设计

  1. 颜色规范
  • 主色调使用品牌色
  • 次要色调搭配主色调
  • 功能色(成功、警告、错误等)保持统一
  • 中性色用于文字、边框、分割线等
  1. 字体规范
  • 字体家族统一
  • 标题字号(20px/18px/16px)
  • 正文字号(14px)
  • 辅助文字字号(12px)
  • 字重设置(regular/medium/bold)
  • 导航字号 Logo , 一级导航,二级导航,三级导航
  1. 间距规范
  • 内边距(padding)使用8的倍数
  • 外边距(margin)使用8的倍数
  • 组件间距保持一致
  • 文本行高1.5倍字号
  1. 圆角规范
  • 大圆角(8px)用于卡片、模态框
  • 中圆角(4px)用于按钮、输入框
  • 小圆角(2px)用于标签、徽标
  1. 阴影规范
  • 浮层阴影(弹窗、下拉菜单)
  • 卡片阴影
  • 按钮点击态阴影
  1. 动画规范
  • 过渡动画(0.3s)
  • 渐入渐出效果
  • hover/active状态变化
  • loading动画

交互规则

展示

  • 超长内容使用 tooltip 展示 并显示省略号
  • 为空时显示“--”
  • 内容均与标题左对齐展示

链接 Link

  • 默认当前页打开
  • 要能够右键新开标签页
  • 打开新链接的位置需要图标标识

按钮 Button

  • 防止多次点击
  • 带请求的需要显示loading

数字

适用场景

产品内统一使用的数字显示

规则

  • 数字统一使用中文
  • 数字统一使用千分位
  • 数字统一使用小数点后两位
基础样式
  • 0.99
  • 0.9
  • 9
  • 99
  • 99+
  • 99万 / 188,888
  • 99W
  • 99%
  • 99.9%
  • 99.99%

日期时间

适用场景

产品内统一使用的日期时间显示

规则

  • 日期时间统一使用中文
  • 日期时间统一使用24小时制
  • 日期时间统一使用小数点后两位
基础样式

1.绝对时间

日期时间使用短杠链接 24小时制时间显示,数字之间用“ : ”作为分隔。

  • 2024-01-01 12:00:00

  • 2024-01-01 12:00

  • 2024-01-01

  • 12:00:00

  • 12:00

  • 星期 周一 周二 周三 周四 周五 周六 周日

  • 2024年01月01日

  • 用于描述时间点的时间单位。 1年1月第1周1日1时1分1秒
    2.相对时间 取值范围

  • 今天 1:00

  • 昨天 1:00

  • 明天 1:00

  • 本周

  • 本月
    时间长度显示

时间单位 过去 当前 未来
1年前 近1年 1年后
1月前 近1月 1月后
1周前 近1周 1周后
小时 1小时前 近1小时 1小时后
分钟 1分钟前 近1分钟 1分钟后
1秒前 近1秒 1秒后

日期筛选

  1. 筛选一天
  • 今天
  • 昨天
  • 明天
  1. 筛选一周
  • 本周
  • 上周
  • 近7天
  1. 筛选一月
  • 本月
  • 上月
  • 近30天
  1. 筛选一年
  • 今年
  • 去年

表格

  1. 表格布局
  • 字段内容
  1. 字段按照比例进行展示,展示不全时在末尾加“...”,hover时有 tooltip 补全字段的内容。

  2. 为空时展示“--”。

  3. 内容均与标题左对齐展示。

  • 表格操作项,固定表尾展示(如编辑、删除、启停等)

  • 表格字段自定义设置,固定表尾展示

  • 对表格内容有全列表选中或有上限提示时,使用header模块

  • 对列表内容有总计或汇总时,使用footer模块

  1. 分页
  • 分页数一般采取每页展示 15条
  • 分页放在右边
  • 显示总数,当前页码,每页条数,总页数

异常状态

  1. 空状态
  • 无数据时展示空状态页面
  • 提供默认空状态插画
  • 可添加引导性文案和操作按钮
  1. 加载状态
  • 页面首次加载时显示骨架屏
  • 局部数据加载时显示loading动画
  • 提供加载超时处理机制
  1. 兼容处理
  • 浏览器版本检测与提示
  • 设备兼容性检查
  • 网络环境检测

安全特性

  • XSS过滤
  • 敏感信息加密
  • 输入长度限制
  • 特殊字符过滤

组件结构设计

基础组件 (Basic)

Button 按钮

  • 主要按钮 (Primary)
  • 次要按钮 (Secondary)
  • 文本按钮 (Text)
  • 图标按钮 (Icon)
  • 加载中状态
  • 禁用状态

Icon 图标

  • SVG图标系统
  • 图标尺寸 标准尺寸
  • 图标颜色
  • 自定义图标
  • 素材的统一管理
    • 字体图标
    • SVG图标

导航组件 (Navigation)

NavBar 导航栏

  • 顶部导航
  • 侧边导航
  • 响应式导航
  • 下拉菜单

Tabs 标签页

  • 基础标签页
  • 卡片式标签页
  • 自定义标签页
  • 动态增减标签页

录入组件 (Form)

输入框 Input

  • 文本输入
  • 字数限制,默认32个字
  • 禁用状态下 不显示灰色,而是普通文本
  • 显示字数统计

时间组件 TimePicker

核心功能

Rules

  • 多样化的时间选择模式

    日期选择 (年/月/日)
    时间选择 (时/分/秒)
    日期时间组合
    时间范围选择

  • 智能时间推荐
    快捷选项(今天、昨天、本周、本月等)
    相对时间(最近7天、近30天、未来一周等)
    自定义常用时间段

选择器 Select

  • 单选下拉框
  • 多选下拉框
  • 可搜索选择器
  • 级联选择器
  • 项目选择器

搜索框 Search

  • 输入框搜索

    • 基础搜索
    • 自动完成搜索
  • 弹框搜索选择 *

    • 单选/多选模式
    • 支持搜索过滤
    • 自定义搜索结果展示
    • 支持分页加载
    • 支持搜索记录
    • 支持不同业务的适配器

人员选择器 UserPicker

  1. 选择模式
  • 单选/多选
  • 部门选择 *
  • 角色选择 *
  • 组织架构树 *
  • 常用联系人
  1. 数据展示
  • 头像展示
  • 在职状态
  • 职位信息
  • 所属部门
  • 联系方式
  1. 高级功能
  • 快速搜索
  • 拼音搜索
  • 历史记录
  • 常用群组

人员显示

  • 头像 人名
    • 横向/纵向
  • 纯头像 / mini small large,

标签选择器 TagPicker

  • 单选标签
  • 多选标签
  • 可创建标签
  • 标签搜索

展示组件 (Display)

通知栏 NotificationBar

  • 普通通知
  • 成功通知
  • 警告通知
  • 错误通知

TODO

  • 需要进行样式设计

卡片列表组件 *

反馈组件 (Feedback)

Dialog 对话框

  • 信息对话框
    • 关闭按钮
  • 确认对话框
    • 操作在右侧
    • 先取消 后确定

Rules

  • 样式统一
  • 不能使用esc 关闭弹框
  • 不能点击侧边关闭弹框
  • 只能点击右上角关闭

轻提示 Toast

  • 成功提示
  • 错误提示
  • 加载提示
  • 自定义提示

加载 Loading

  • 全屏加载
  • 局部加载

业务组件

甘特图 GanttChart

  • 基础甘特图
  • 可拖拽甘特图
  • 自定义甘特图

可编辑表格 EditableTable

  • 基础可编辑表格
    • 能容展示
    • 操作列
  • 可编辑表格
    • 可编辑
    • 可排序
    • 可过滤
    • 分组
  • 高级功能
    • 支持拖拽
    • 支持右键操作
    • 插件系统
      • 可编辑组件插件
      • 业务逻辑处理插件 单元格显示,编辑,过滤,排序等设置钩子
  • 基于表格的应用
    定义应用业务,定义字段属性,定义业务节点

全景图

  • 基础全景图
  • 自定义全景图

编辑器

  • 富文本编辑器
  • AiEditor
  • Umo 编辑器
  • 高级功能
    • 支持通用业务实例插入进文本
    • 展示卡片模式
    • 可编辑卡片
    • 预览卡片

看板

  • 基础看板

  • 自定义看板

    • 支持看板大小拖拽
    • 支持看板单模块查看,根据路由查看
    • 支持看板模块全屏
    • 看板自动刷新/手动刷新

树形组件 TreeComponent

使用场景分类
  1. 目录树: 文件系统展示,支持展开/收起、选择等操作 (统一化改造)
  2. 下拉选择树: 层级数据选择,如组织架构、地区选择 (统一化改造)
  3. 标签树: 分类标签展示和管理
  4. 层级树: 展示具有明确层级关系的数据结构
  5. 可选择树: 支持单选、多选,适用于数据选择场景

其他平台组件

  • 快捷工具栏 :最小化弹框,下次能够快速打开

方案计划

基本原则

  • 先出方案,后改造,(明确基本要求+其他特殊要求)
  • 明确改造范围
  • 组件输出结果可评估

统一化改造

平台组件改造工作分为两部分基础组件的改造 && 业务组件的改造抽离

样式统一

  • 难度:☆☆
  • 涉及范围: 和新版样式改造一起改

交互统一

  • 难度:☆☆☆
  • 涉及范围:确认按钮,表格操作,

组件统一化改造

  • 难度:☆☆☆☆
  • 涉及范围:时间控件,人员控件,部门控件,其他表单控件,表格,卡片

业务组件的改造

组件统一化改造完成后,需要分析决定哪些业务组件需要进行改造

组件分类

非必要改造组件

可改造增强组件

  • 人员选择器

可挖掘组件

  • 支持不同业务的,插件化可编辑表格组件
  • 甘特图

平台情况摸查整理 (2d)

  • 整理平台哪些功能点需要改进
  • 总结分类,评估时间
  • 划定改造范围

开发人员角色工作分配

A 负责平台统一

B 负责基础组件开发

C 负责支援,两方都做,同时进行检查,查漏补缺

组件开发可检查项(评审要求)

  • 是否满足基本的交互要求 (loading,再试,样式规则)
  • 是否满足基本设计样式规范
  • 处理了哪些性能问题(是否有数据问题)
  • 处理了哪些安全问题
  • 整理哪些有可改进方向
  • 数据多的时候有没有采用优化方案

通用组件库搭建

组件开发规范

目录结构

components/
├── basic/
├── navigation/
├── form/
├── display/
├── feedback/
└── business/

组件API设计原则

  • 属性命名语义化
  • 提供默认值
  • 完善的类型定义
  • 事件命名规范
  • 插槽灵活性

样式规范

  • BEM命名规范
  • 主题定制
  • 响应式设计
  • CSS变量支持

内存管理

通用能力

  1. 性能优化
    虚拟滚动
    懒加载
    数据缓存
    按需渲染

  2. 可访问性
    键盘操作支持
    主题定制
    响应式适配

  3. 开发友好
    完整的单元测试
    详细的API文档
    丰富的示例代码

组件质量

单元测试

  • 使用 Jest + Vue Test Utils 进行单元测试
  • 测试覆盖率要求达到 80% 以上
  • 测试用例包含:
    • 组件渲染测试
    • Props 传值测试
    • 事件触发测试
    • 插槽内容测试
    • 异步行为测试
    • 边界条件测试

组件文档 (Storybook)

  • 使用 Storybook
  • 文档结构:
    • 组件介绍
    • Props API 说明
    • 事件说明
    • 插槽说明
    • 使用示例
    • 在线预览
  • 支持主题切换
  • 支持代码复制

示例工程

  • 包含所有组件的使用示例
  • 提供常见业务场景的最佳实践
  • 支持在线预览和代码查看
  • 提供完整的工程配置说明

性能测试

组件渲染性能测试

  • 首次渲染时间
  • 重渲染时间
  • 内存占用

大数据渲染测试

  • 虚拟滚动性能
  • 懒加载性能

交互响应测试

  • 事件处理延迟
  • 动画流畅度

自动化性能测试

  • 使用 Lighthouse 进行性能评分
  • 设置性能指标基准线
  • 性能回归测试

内存管理

组件生命周期管理

数据缓存策略

数据缓存策略

性能指标监控

性能指标监控

定时器管理

组件开发规范

  1. 及时销毁
  • 组件销毁时清理所有事件监听
  • 组件销毁时清理所有定时器
  • 组件销毁时清理所有订阅
  1. 数据处理
  • 大数据列表使用虚拟滚动
  • 及时清理不需要的数据引用
  • 避免深层数据结构
  1. DOM操作
  • 避免频繁DOM操作
  • 使用DocumentFragment优化批量操作
  • 及时移除不需要的DOM节点

代码审查清单

  1. 资源清理检查
  • 是否正确使用beforeDestroy钩子
  • 是否清理了所有事件监听器
  • 是否清理了所有定时器
  • 是否清理了所有订阅
  1. 性能检查
  • 是否使用了合适的缓存策略
  • 是否处理了大数据场景
  • 是否避免了内存泄漏风险
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容