浅谈业务中台前端设计

news2024/11/15 23:35:11

做前端中台业务一年多的时间,有一些心得体会,和大家分享分享。

  • 中台是什么
  • 中台业务的价值是什么
  • 做了哪些前端中台业务
  • 如何设计前端中台业务
  • 未来展望

中台是什么

百度百科的解释比较言简意赅:“中台,互联网术语,一般应用于大型企业。一般是指搭建一个灵活快速应对变化的架构,快速实现前端提的需求,避免重复建设,达到提高工作效率目的。” 当公司发展到一定规模,就需要建设中台团队来提高工作效率。 在前后端分离的协作模式下,会分为后端中台、前端中台。 对于前端中台来讲,常见的有BFF中台、业务中台等等。 我今天要分享的,主要是业务中台的一些经验。

中台业务的价值是什么

中台业务的大背景,诞生于“降本增效”的大号角下。 无论公司大小,无论业绩如何,“降本增效”一直都是一个不变的、可以挖掘的话题。 企业需要盈利,除去增加利润之外,经营成本也是需要考虑的重要部分。而人力成本或者说协作成本作为经营成本的重要组成,投入一定的时间和经历,产出服务或者工具,从而降低成本

做了哪些前端中台业务

大致列举一下。

  • 低代码加载器(xxx官网接低代码平台前端技术方案)
  • 统一登录页(xxx账号统一过渡页业务线对接)
  • webComponents(webComponents版本管理方案设计)
  • 微应用(微应用主子应用通信设计、微应用前端按配置渲染)
  • 网关插件(xxx与yyy免登、zzz ISV优化对接文档)

光看业务可能比较模糊,下面来谈谈技术实现细节。

项目技术
低代码加载器@xxx/yyy-hydrate、next slug路由
统一登录页localStorage天然域名隔离、前端网关proxy
webComponents@xxx/direflow-component、@xxx/direflow-utils、@xxx/direflow-deploy、前端网关接口、webpack复制重命名插件
微应用localStorage、React Context
网关插件基于koa的BFF网关

如何设计前端中台业务

关于如何设计前端业务,我觉得主要有几个方面需要考虑

  • 通用性尽可能强
  • 使用方接入尽可能简单
  • 文档尽可能详细、更新及时
  • 接入前自测并充分相信接入方

通用性尽可能强

通用性强其实有一个非常大的前提:前端技术栈统一、前端基建完善(比如前端网关、前端发布平台)。 得益于TUYA前端技术栈统一为基于next.js的React技术栈,以及完善的前端基建,通用性强这一点有着先天的不用考虑兼容性的优势,只需要考虑“业务通用”即可。 例如在xxx业务线,有业务线A、业务线B、业务线C、业务线D、业务线E等等业务线。 在开发中台业务时,主要需要考虑:技术方案在各个业务线是否通用?

举例来说:

  • 前端组件如何既兼容UI框架 v3,又兼容UI框架v4
  • 网关插件是否既支持协议A,又支持协议B
  • 若项目以微应用子应用方式下沉,主应用是否具备接入能力
  • 微应用前端按配置渲染,context方式可以无感注入到hook及组件

使用方接入尽可能简单

前端中台设计,面向的是业务线各团队的前端提供服务。 如何让“使用方接入尽可能简单”,这个可谓是非常重要。

举例来说

  • 低代码加载器接入:遇到next版本不一问题,需要一一统一。只有统一后,才能统一使用npm包接入
  • 统一登录页:数据存储localStorage、配置代理即可
  • webComponents:初期以script脚本链接接入、后期优化为脚本实时接入和更新;组件功能尽可能收敛,减少接入方工作量
  • 微应用:主子应用统一通信方式为foo,提供统一子应用获取应用信息npm包
  • 网关插件:尽可能将逻辑收敛到网关插件内部,例如登录态获取、api调用、redirect等等

文档尽可能详细、更新及时

一份清晰、易用的文档非常重要。 可以帮助接入方更快速的接入,可以节约很多沟通时间。 如果链路较为复杂,尽可能提供一份清晰的链路图(推荐使用mermaid绘制链路图)。

文档主要考虑几个方面

  • api / props 说明
  • 清晰的demo
  • 文字少一点,一图胜千言
  • 链路图、架构图、原理图
  • changelog(如果更新非常频繁的话)
  • 容易踩坑的一些友好提醒备注

接入前自测并充分相信接入方

在做前端中台初期,公共模块开发完成后,我会直接在业务线的项目中,做一次接入测试,确保链路可通、服务可用。 当服务在第一条业务线接入成功,并且在线上成功运行时,功能可用性已达成。 当有第二条业务线接入时,虽然接入方对链路不清楚,但是作为服务提供方,已经有了自测以及第一条业务线的接入,需要充分相信对方,辅助接入即可

未来展望

除去上述的很多方法论或者说经验之外,想要做好业务中台前端设计,还有很多事需要做:

  • 增强服务意识和沟通能力
  • 拥抱新技术、拓宽技术栈
  • 提升代码通用性、内聚性

最后

整理了一套《前端大厂面试宝典》,包含了HTML、CSS、JavaScript、HTTP、TCP协议、浏览器、VUE、React、数据结构和算法,一共201道面试题,并对每个问题作出了回答和解析。

有需要的小伙伴,可以点击文末卡片领取这份文档,无偿分享

部分文档展示:



文章篇幅有限,后面的内容就不一一展示了

有需要的小伙伴,可以点下方卡片免费领取

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/342995.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[数据库]表的约束

●🧑个人主页:你帅你先说. ●📃欢迎点赞👍关注💡收藏💖 ●📖既选择了远方,便只顾风雨兼程。 ●🤟欢迎大家有问题随时私信我! ●🧐版权:本文由[你帅…

【MySQL】MySQL 中 WITH 子句详解:从基础到实战示例

文章目录一、什么是 WITH 子句1. 定义2.用途二、WITH 子句的语法和用法1.语法2.使用示例3.优点三、总结"梦想不会碎,只有被放弃了才会破灭。" "Dreams wont break, only abandoned will shatter."一、什么是 WITH 子句 1. 定义 WITH 子句是 M…

LeetCode——1234. 替换子串得到平衡字符串

一、题目 有一个只含有 ‘Q’, ‘W’, ‘E’, ‘R’ 四种字符,且长度为 n 的字符串。 假如在该字符串中,这四个字符都恰好出现 n/4 次,那么它就是一个「平衡字符串」。 给你一个这样的字符串 s,请通过「替换一个子串」的方式&a…

Kubeadm搭建K8S

目录 一、部署步骤 1、实验环境 2、环境准备 3、所有节点安装Docker 4、 所有节点配置K8S源 5、所有节点安装kubeadm,kubelet和kubectl 6、部署 kubernetes Master 节点 7、token制作 8、k8s-node节点加入master节点 9、 master节点安装部署pod网络插件&a…

ChatGPT被玩疯,问“如果美国倒了,世界会怎样?”回答太吓人了

“ChatGPT”大火不见消停…… 最近这些天,想必大家的社交平台都刷爆了“ChatGPT”这个词吧? 作为OpenAI 的语言模型工具,它可以生成文本、回答问题、对话、摘要、翻译等。 特点是语言表达流畅,思维敏捷,可以回答复杂…

golang语言本身设计点总结

本文参考 1.golang的内存管理分配 golang的内存分配仿造Google公司的内存分配方法TCmalloc算法;她会把将内存请求分为两类,大对象请求和小对象请求,大对象为>32K的对象。 在了解golang的内存分配之前要知道什么事虚拟内存,虚拟内存是把磁盘作为全局…

设计模式之工厂模式详解和应用

目录1 工厂模式的历史由来2.简单工厂模式2.1 简单工厂模式定义2.2 简单工厂模式案例2.3 简单工厂模式相关源码2.4 简单工厂模式优缺点3 工厂方法模式3.1 工厂方法模式定义3.2 工厂方法模式案例3.3 工厂方法模式源码3.4 工厂方法模式优缺点4 抽象工厂模式4.1 抽象工厂模式定义4.…

【项目】基于SpringBoot+Freemarker+Mybatis+MySQL+LayUI实现CRM智能办公系统

这里写目录标题CRM基本概念CRM分类模块功能描述项目代码application-dev.yml部分页面代码CRM基本概念 圈内存在这么一句话:“世上本来没有 CRM,大家的生意越来越难做了,才有了 CRM。” 在同质化竞争时代,顾客资产尤为重要&#x…

CUDA流入门|参加CUDA线上训练营

CUDA 流的概念 CUDA流在加速应用程序方面起到重要的作用,他表示一个GPU的操作队列操作在队列中按照一定的顺序执行,也可以向流中添加一定的操作如核函数的启动、内存的复制、事件的启动和结束等,添加的顺序也就是执行的顺序一个流中的不同操…

SQLi-LABS-Challenges 0~28a解析

Less-1 GET-Error based - Single quotes - String 成功payload 1 union select 1,database(),user()%23 1 and 12 union select user(),1,database()-- 经测试 输出时会输出 3 列,所以此处 union select 需 select 三个数据 * 1‘ order by 4--时会报错&#…

OpenHarmony使用Socket实现一个TCP服务端详解

点击获取BearPi-HM_Nano源码 ,以D4_iot_tcp_server为例: 点击查看:上一篇关于socket udp实现的解析 查看 TCPServerTask 方法实现: static void TCPServerTask(void) {//连接WifiWifiConnect("TP-LINK_65A8",

场测|新能源整车通信功能性能,新能源整车环中国测试,整车2345G及bt,wifi测试

一套全新的用于测试车载通信功能的标准Verson.DH2.0.0 目的: 检测出不同平台、芯片及硬件配置的间的差异,找到凌驾于法规之上好产品配置。开创出行业领先的测试标准,并联合相关部门将地方标准升级成国家标准。推动行业产品的迭代将客户的用…

Ajax 学习笔记

一、Ajax1.1 什么是AjaxAJAX Asynchronous JavaScript and XML(异步的JavaScript和XML)。Ajax是一种在无需加载整个网页的情况下,能够更新部分网页的技术,它不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术…

VSCODE C++ 调用matplotlibcpp画图

使用VSCODE编写C程序,想在调试过程中看中间数据的波形,于是找到了python的matplotlibcpp库,参考文章链接是:https://blog.csdn.net/weixin_43769166/article/details/118365416;按照他的步骤配置好之后,跳出…

《爆肝整理》保姆级系列教程python接口自动化(十三)--cookie绕过验证码登录(详解

python接口自动化(十三)--cookie绕过验证码登录(详解 简介 有些登录的接口会有验证码:短信验证码,图形验证码等,这种登录的话验证码参数可以从后台获取的(或者查数据库最直接)。获取…

Linux服务器clang-13安装(环境变量配置)

1.从llvm的github网址选择合适的release合适的运行平台进行下载,下载官方预编译的二进制压缩包。 2.将下载好的压缩包进行本地上传。 使用scp命令进行上传 scp -r -P 端口号 本地文件路径 服务器ID等:服务器上目标地址 3.解压(tar命令) 4.环境变量配…

测试开发之Django实战示例 第八章 管理支付与订单

第八章 管理支付与订单上一章制作了一个带有商品品类展示和购物车功能的电商网站雏形,同时也学到了如何使用Celery给项目增加异步任务。本章将学习为网站集成支付网关以让用户通过信用卡付款,还将为管理后台扩展两项功能:将数据导出为CSV以及…

旋转框目标检测mmrotate v1.0.0rc1 之RTMDet训练DOTA(二)

1、模型rotated_rtmdet的论文链接与配置文件注意:我们按照 DOTA 评测服务器的最新指标,原来的 voc 格式 mAP 现在是 mAP50。IN表示ImageNet预训练,COCO表示COCO预训练。与报告不同的是,这里的推理速度是在 NVIDIA 2080Ti GPU 上测…

国外客户只想跟工厂合作?可以这样破解

1.客户是愿意和外贸公司合作还是更愿意和工厂合作?一个外贸公司的朋友说:“我去工厂接待过七八次外国人,基本上都是英国、德国、日本、加拿大、美国的。”贸易公司根本不避讳自己是贸易公司,外国人也不在乎。他们更关心的是贸易公司能否妥善安…

十五载厚积薄发,电信级分布式数据库是这样炼成

所在论坛:数据库技术创新&云原生论坛 分享时段:2.18 10:00-10:30 分享主题:大规模并行处理:AntDB分布式演进之路 分享嘉宾:沈夺,亚信科技AntDB数据库内核开发工程师 由中国开源软件推进联盟Postgre…