分享 ppt 可关注「fliggy f2e」微信公众号,回复 ppt 可获取!

总览

大家好,我是飞猪前端侑夕,今天分享的主题是《如何落地微前端一体化运营工作台》,首先简单的介绍一下自己,花名叫做侑夕,今年 主要是弄飞猪微前端一体化运营工作台的建设,也即今天分享的主题

将从「为什么要做飞猪一体化运营工作台、要做成什么样子、怎么做的、后面想怎么做」这 4 块来给大家讲述。


为什么要做飞猪一体化运营工作台

飞猪运营属性的发展

在 12 年的时候,阿里 ALLIN 无线过程中,飞猪 App 当时也随之产生了,相当于工具属性,用于给用户快速查询机票门票信息;等到了 14 年左右工具属性逐步丰富起来,同时经过双十一的火爆,慢慢转变成一个营销卖货的属性,当时各种营销平台慢慢做起来了;

到了 17 年左右,当时主打场景运营心智,包括出境超市、周末好去处等主题心智,导购类平台在这个时候逐步萌芽;等到了 18 年后随着抖音/直播的火爆,飞猪运营类型也更加丰富起来了,由主题进化到内容心智。


随着业务逐步丰富发展,内部的各种小二运营平台也在从「可用提效」往「精耕细作」发展,随着运营一体化工作台的建设,目前正处在下图箭头处


发展过程中的痛点

伴随飞猪业务的发展,我们在近两年为提升运营效率建立了多种场景的运营类平台,可满足运营完成业务诉求。


但随着产品本身业务复杂度在不断提高,只能给运营解决温饱问题,加上各平台需要互投互通诉求逐渐强烈,在此体系下无法给业务带来 1 + 1 > 2 的价值,面临如下继需解决的痛点:


要做成什么样子

为解决以上痛点,我们启动一体化运营工作台建设项目,旨在借助新技术探索和升级给运营同学提供更好更高效的运营平台解决方案,一期目标为技术侧的探通,完成工作台框架的搭建,满足多平台场景使用,沉淀一套以现有业务为基础的泛运营平台微前端解决方案


基于此我们从实际业务运营配置场景入手,结合现有中后台技术和微前端解决方案,产出如下方案架构图:


底层借助 Ant Design 体系加上 qiankun 的能力,中间层辅助一体化工作台里面涉及的贴合现有业务场景的规范;更上一层沉淀组件化 widget 的能力,用于各种功能的互通,同时成为现有子应用的组合来源;在最上层即飞猪运营工作台的上层主应用,包括整体框架、快捷导航、权限登录控制、运营场景的汇集,包括后续要做的业务运营 SOP 解决方案。

怎么做的


前端侧深度使用共建 qiankun

在前端侧,我们深度使用和更共建 qiankun,qiankun 底层应⽤之间的加载使⽤ single-spa,上层实现样式隔离、js 沙箱、预加载等上层能⼒,同时提供umi-plugin-qiankun来解决 umi 下的快速使用,成为我们前端侧的选择方案。


在子应用路由控制这一块,我们通过借助现有 antd pro 的路由配置,加上 qiankun 的配置项整合成一个通过的配置 config,借此对于子应用的接入只需配置此处即可,同时可以做到后面的统一管控。


前端侧除了微前端还有路由这一块,其实还包括可以做的更多的事情,包括我们整合了公共资源如 antd、loadsh、router 等等统一大版本,通过写了 umi-externals-url 进行处理,借此可以减少将近 1/3 的资源;包括在体验度量方面我们借助内部的能力,可以将使用用户进行分层分析包括错误性能监控;同时产出具备可以录屏、截图的在线反馈系统,便于用于在使用过程中直接反馈通知直接 issue 提交给对应的负责同学;


后端侧自建统一网关串通主子应用

在后端侧,我们在运营工作台 Node 侧自建了 Gateway 网关 middleware,底层依赖http-proxy-middleware能力实现,借用服务端 proxy 转发接口同时在请求上加上 token 来解决接口登录权限以及跨域的问题,同时对于主子应用直接接入会出现内网登录登录权限不通的问题,此处我们使用的 免登授权 的能力,让子应用的登录让主应用本身来提供,这样通过中间网关层配合我们给 qiankun pr 的 Fetch 自定义能力和 Slave Namebase 可解决请求和路由跳转的兼容问题。


Widget 业务组件化

微前端可以很好解决主子应用间无缝的接入问题,但是对于区块场景还不成熟,存在现有问题:

  • 随着业务场景的成熟发展,加上区块能力嵌入配置的场景逐步增多;
  • 借此解携抽离原有通用招造投搭能力,减少维护压力;
  • 逐步丰富现有 widget 能力,满足后续更多场景的接入使用,以及系统打通

基于此我们通过类 widget npm 组件包的方式来实现业务组件,包括制定对应的协议来驱动对应的 widget 渲染和展示,便于后端同学对其更加可控,同时在视觉规范上,我们收拢各种场景下的使用展示,便于一个 widget 可以更加无缝的嵌入到已有系统

如我们想做搭建系统里面配置互动玩法的配置,借助互动玩法配置 widget 可以达到如下的一体化配置:


运营平台的交互体验

说到中后台的的前端侧展示,大部分场景都没有设计交互同学支持,加上一线研发同学对交互视觉标准的理解不同,导致不少页面的使用体验勉强只能达到能用的状态,距离好看好用还有很大距离。


基于此,我们梳理几类运营场景的视觉规范需要把握的原则点:

  • 同类统一:不折腾,通用层面遵循 Ant Design;同类型 / 同功能模块展示保持一致
  • 舒服对齐:对齐会让页面或者强迫症的同学看起来会很舒服;标题、按钮、表单、tag 多集合类需确保对齐
  • 不常用的收起:将不重要内容收起,便于让用户找关键执行点;类表格将不常用的内容隐藏或者放到抽屉里面去
  • 简单不阻碍:让新用户不看说明书也可以知晓下一步操作;不能让用户由于 XXX 原因走不到下一步

比如说如下的展示:


通过将现有的原子类展示统一后,再往后走,我们将现有的开箱即用进行统一交互,然后沉淀出对应的能力,包括搜索列表、场景卡片组、表单预览的能力,有了这些能力的沉淀,后续新页面的产生较之前可上升一个大的阶段


如 FormRender 的表单的沉淀,我们可以借此此能力可以生产大量的表单页面,同时展示完全让后端侧来控制展示,这样可以做到协议驱动展示,更多详细可见 alibaba/form-render


后面想做啥

以上即我们第一个阶段做的事情,对于下一期重点会放在场景 SOP 能力的开发,同时在中间层进行开箱即用的疯狂提效,底层进行更多的抽象以及规范化,最底层在工程上形成统一的初始化、发布的能力


对于运营配置的场景,最终目的是为了提升运营配置的效率以及可以不断通过数据来优化业务的使用效果,后续我们将以 SOP 的形式逐步来优化运营侧的配置,最终形成一体化的配置能力;


对于技术侧,将尝试更多的新技术探索,特别在微前端规范统一方面,如何让现有系统可以接入目前主流的微前端的子应用能力,包括上层子应用的管控平台;同时目前的新打包体系或许可以给我们很多新的思路来扩充现有的打包的能力;以及上述的开箱即用协议驱动的搭建如何通过低代码的搭建的方式来更多提升我们的快速生成的能力!


Welcome 来飞猪

广告时间到啦,其实飞猪前端团队在阿里是一个比较厉害的前端团队,拔赤大大 P9 带队,整体成员有成熟的高 P 也有年轻的小鲜肉,大家都技术思想都很 Open,平时生日会、团队、出国 outing,不亦乐乎


在技术上,目前我们在新颖技术、中台技术、基础技术上均有团队规划发展,如果你比较感兴趣,可以直接来聊,同时有能力过来带一个方向也是很欢迎的!


最后也很欢迎,关注飞猪前端公众号,里面有不少体系化建设的文章干货,值得一读!


三级工作台抽奖出啥_【早早聊】如何落地一体化运营工作台相关推荐

  1. 前端怎么使用jsessionid_前端搞微前端 | 侑夕 - 如何落地微前端一体化运营工作台...

    下期预告 前端早早聊大会目标成为用得上.听得懂.抄得走的技术大会,计划 2020 年办 >= 15 期,由前端早早聊与掘金联合举办,前端早早聊大会行程动态.录播视频/PPT/讲稿资料下载请关注 ...

  2. qiankun 传统项目配置_飞猪微前端实践:统一运营工作台的解决方案-阿里云开发者社区...

    作者:侑夕 飞猪一体化运营工作台一期工作经过 3 个月的开发终于内部开始使用,期间我们面向运营场景,基于微前端与 SDK 化的一体化集成方案,完成 4 大场景 10 余个平台的接入和配置打通,并对数百 ...

  3. Android Studio的res自动生成的文件出错了_莫韵乐与bug的奇妙冒险

    Android Studio的res自动生成的文件出错了_莫韵乐与bug的奇妙冒险 无论学什么编程语言都要跟奇怪的bug过不去 奇怪的bug出现了 今天满怀欣喜地进行安卓开发学习,创建好一个新的项目之 ...

  4. 如何搞定不同公司的算法面试?(早早聊分享文字版)

    前几天西法参加了<前端早早聊>第 24 界的分享.我的分享主题是<如何搞定不同公司的算法面试?> 这是这次分享的文字版,供大家查看.如果大家需要分享的原版 ppt,也可以到我的 ...

  5. arcgis批量出图python代码_【GIS进阶】ArcGIS批量出图_定义出图

    今天的文章是浩哥投稿!!! 下图是我欢呼雀跃的样子~~~~~ 本文亮点: 所有步骤都是用ArcGIS中各种工具和软件操作组合,未使用Arcpy与Python等需要使用代码的工具! 这次的这个批量出图又 ...

  6. 如何用C语言写出一个微信群聊机器人

    要用 C 语言写出一个微信群聊机器人,您需要先了解微信群聊的相关信息和 C 语言的编程知识. 首先,微信群聊是通过微信服务器进行通信的,因此您需要了解如何通过网络协议与微信服务器进行通信.微信群聊使用 ...

  7. 数字抽奖小程序_如何利用小程序玩转抽奖活动?

    抽奖作为一种古老的运营套路,一直活跃在营销最前沿.无论是线下门店促销,还是线上活动,抽奖被广泛用于拉新.促活.获客等增长环节.虽然玩法看似老套,但凭借着以小博大的杠杆效应.低门槛参与.高奖励诱惑的活动 ...

  8. cpc卡内计费信息异常包括_抖音信息流落地页直达广告怎么做?

    据数据显示,抖音用户60%以上是90后用户,70%以上的用户来自一二线城市,男女比例基本持平,抖音广告适合以中年轻群体为目标用户的企业投放.抖音广告可以直接点击跳转到指定的落地页,那么,抖音官方信息流 ...

  9. 抽奖的箱子_王者荣耀近期问题不断,昭君星元箱子开出空气,瑶新皮涉嫌抄袭...

    相信小伙伴们都知道,王昭君出了四套新星元,在这些星元当中大部分能够直接获得,但有一套高质量的却需要抽奖才能得到. 按照官方的说法,买宝箱就能进行抽奖,而星元部件的掉落概率则是13%,乍看之下还挺高,但 ...

最新文章

  1. 让你的eclipse插件只下载一次
  2. 成都理工大学乐千桤java考试_2009年度优秀教师、优秀教务工作者评选结果公示-成都理工大学工会...
  3. 图解Oracle包实例
  4. java sortedset_Java类集-SortedSet接口 | 学步园
  5. 一分钟学会Git操作流程
  6. 【转】C# 命名空间 Namespace (学习心得 23)
  7. MySQL数据库的设计和命令行模式下建立详细过程
  8. jQuery实现点击行(tr)选中某列中CheckBox
  9. Win10常用命令:定时关机(shutdown命令)
  10. 中班机器人歌曲_幼儿园机器人教案音乐
  11. windows上编译,使用libtorrent
  12. 【无标题】 2022淘宝天猫双十一喵果总动员玩法攻略
  13. 《编码-隐匿在计算机背后的语言》 —— 读书笔记(三):数字
  14. linux拼音五笔输入法下载软件,万能五笔输入法
  15. 脚踏实地才能仰望星空
  16. java sql 违反协议_java.sql.SQLException: 违反协议异常的一种解释
  17. windows10开启/关闭超级管理员账号登陆
  18. JavaScript变量提升(Hoisting)详解
  19. 根据出生日期计算年龄(精确到天)
  20. 实例演示R语言制作限制性立方条图

热门文章

  1. python读取文件读不出来-python文件读取失败怎么处理
  2. python职能-高级Python开发工程师职位描述与岗位职责任职要求
  3. python画出心形图-python画心型图案
  4. java和python的比较-Python和Java就业前景对比
  5. python培训出来的有公司要吗-目前从事Python培训的机构有很多家
  6. python爬虫框架排行榜-公认8个效率最高的爬虫框架
  7. python里面temp是啥-Python tempfile模块学习笔记(临时文件)
  8. python是c语言写的吗-python和C语言的差别
  9. mysql数据库约束无符号_mysql 数据类型 约束条件
  10. 操作符*或者-的重载