前端框架的不断变化,对不同行业产生了诸多的影响。目前,前端的发展趋势究竟是什么样的?为了解更多的前端趋势相关内容,让我们跟随本文,看一下像阿里巴巴这样的互联网大厂,是怎样做的。
进入 2019 年,大前端技术生态似乎进入到了一个相对稳定的环境,React 在 2013 年发布至今已经 6 年时间了,Vue 1.0 在 2015 年发布,至今也有 4 年时间了。
整个业界在前端框架不断迭代中,也寻找到了许多突破方向,例如跨平台中的 RN、Flutter,服务端 GraphQL、Serverless,前端和客户端的融合越来越紧密,前端在 Node 和 Electron 的加持下,也扩展了自己的版图到服务端和桌面。
同时,随着前端开发越来越复杂,整个前端研发也经历了人工化 -> 工具化 -> 工程化 -> 智能化的演变。目前各个大厂在工程化实践不断迭代,出现了许多 Low/No Code 等前端智能化解决方案,工程化实践也深入到研发的各个环节,不断提升前端研发的标准化能力。而且,随着机器学习的加入,各类 UI2Code 的解决方案也开始出现,前端研发进入了一个完全不同的时代。
随着端上能力的不断增强,现在在端上做的事情越来越多。首先,数据可视化方向,各类图表、地图、3D 等等数据可视化的尝试变得越来越多。其次,伴随着人工智能的加持,在端上的人工智能应用也变得普及,减少了服务端的交互,提高了系统的实时响应能力。最后,随着 WebAssembly 等技术的应用,有可能将前端运行能力再提升一个档次,可以进行更为复杂的端上计算。
为了了解当前前端的发展趋势,让我们从国内各大互联网大厂开始,了解他们的最新动态和未来规划。
第一篇先从阿里巴巴开始。
阿里巴巴前端团队介绍
阿里巴巴集团一定是国内前端技术发展的高地,其完整经历了 PC 时代、移动时代和智能时代,具有非常繁杂的业务场景,同时沉淀开源了众多前端项目,因此非常值得学习借鉴。
蚂蚁金服体验科技
技术专栏: https://zhuanlan.zhihu.com/xtech
蚂蚁金服体验技术部,是阿里巴巴经济体内,一支以用户体验、大前端和创新产品为核心竞争力的年轻团队。「那些年的体验技术部」开源了 Ant Design、AntV、Egg.js、Umi 等一系列项目。
设计不只是好看,更关乎好用。体验科技就是技术与设计的融合,是服务与用户的连接。在前端技术上,不仅仅要实现页面的交互,更要通过产品、技术、设计的融合,实现好的用户体验。
蚂蚁金服体验科技提供了完整的前端解决方案:
淘系前端团队
技术博客: https://fed.taobao.org/
淘系前端团队是服务于淘宝、天猫、聚客宝等电商业务的前端团队,他们面临国内最复杂的电商系统,也需要面对大量的终端用户。在这个团队中孵化了许多开源项目,例如 Rax- 通用模板渲染引擎、飞冰 - 前端可视化搭建平台、imgcook- 前端智能化生成平台等等。
饿了么大前端团队
技术专栏: https://zhuanlan.zhihu.com/ElemeFE
饿了么大前端团队是一个集前端、iOS、Android、BFF 后端一起的技术研发团队,其最著名的是基于 Vue 的两个开源项目:
-
element:基于 Vue 的 PC 端的 UI 组件库。
-
mint-ui:基于 Vue 的移动端 UI 组件库。
同时还有各种基于 Vue 的封装组件库,例如 vue-amap 是一个高德地图组件,v-charts 是一个基于 Vue2.0 和 ECharts 封装的图表组件库。
闲鱼技术团队
技术博客: https://www.yuque.com/xytech
闲鱼技术团队过去一年在 Flutter 技术方向的沉淀非常丰富,目前已经大量采用 Flutter 于闲鱼 App 中,同时开源了若干 Flutter 生态相关的项目:
-
Fish Redux 是一个基于 Redux 数据管理的组装式 flutter 应用框架, 它特别适用于构建中大型的复杂应用。
-
FlutterBoost 是一个 Flutter 插件,它可以轻松地为现有原生应用程序提供 Flutter 混合集成方案。
基础设施
基础设施 依赖于阿里云的基础设施,提供 Serverless、AI、IoT、云计算、安全等基础能力。
Serverless 函数计算:阿里云提供了云函数计算能力,同时可以辅助与现有的 BaaS 能力,进行存储、数据库、通信的能力。
CDN:CDN 可以用于静态资源的存储,发放资源到用户就近的节点,极大地提高用户访问的速度体验。
移动测试平台:真机测试的云平台,帮助解决用户的真机兼容、性能等问题,提升用户体验。
应用实时监控服务 ARMS:一款应用性能管理产品,包含前端监控、应用监控和 Prometheus 监控三大子产品,能帮助你实现全栈式的性能监控和端到端的全链路追踪诊断。
Node.js 性能平台: 是面向中大型 Node.js 应用提供性能监控、安全提醒、故障排查、性能优化等服务的整体性解决方案。
前端服务层框架
BFF - Backend for Frontend
BFF 是目前一种前后端分离的常用研发模式,通常 BFF 作为胶水层,解决了终端对于数据多样性的问题,通过对后端微服务进行聚合,从而提供各种定制化的数据给到终端应用。
在 BFF 技术选型上,选用 Node 是为了技术栈的统一,从而可以让前端同学从前端 UI 实现到聚合层接口实现都通过 JavaScript 完成。这样服务端同学只需要按照领域设计原则暴露各个领域的标准化接口,其他部分前端同学可以通过灵活组合满足各种页面的数据服务需求,达到前后端的分离和研发效率提升。
前端服务层 基于 Node.js 和 Koa 实现了 Egg 框架,Egg.js 为企业级框架和应用而生,由 Egg.js 孕育出更多上层框架,帮助开发团队和开发人员降低开发和维护成本。Egg 提供了一个完善灵活的插件机制,并且奉行约定优于配置。在 Egg 上层,各个业务团队又各自封装了不同的服务层框架,例如蚂蚁 Chair、淘宝 Midway、UC Nut 等等。
BFF in Serverless
Serverless 是阿里内部一个非常重要的方向,目前阿里云已经提供云函数的能力,然后再基于现有的 BaaS 能力(通信、用户、存储、运维、通知),可以实现 BFF 层使用云函数来实现,从而大大减少了服务器资源的消耗,也极大地减少了前端开发同学对于服务器运维的要求。
前端应用层框架
TWA - Techless Web Apps
TWA 是期望能够实现技术无感化的应用,通过全栈研发框架,将前端客户端代码和服务端代码整合在一个代码仓库。通过一站式的研发运维平台,提供极简研发流程和自助式的运维体验,让研发更加关注业务实现,不用太关心“应用”、“构建”、“部署”、“流程”等细节。
前端应用框架 -Bigfish/Umi
Bigfish 是蚂蚁金服前端的开发框架,从上图中可以看到 Bigfish 是一个前端研发全流程的研发框架,涵盖设计师(设计师工具、资产市场、文档、培训)、开发者(部署、插件市场、基础开源框架),同时也包含外部服务(体验、监控等等)。
Umi 是一个可拔插企业级的 React 应用框架,它通过实现沉淀大量最佳实践,极大地实现了 React 应用框架的统一性,同时它也具备非常强的插件扩展能力。它有几大特点:
-
插件化:umi 的整个生命周期都是插件化的,甚至其内部实现就是由大量插件组成,比如 pwa、按需加载、一键切换 preact、一键兼容 ie9 等等,都是由插件实现。
-
开箱即用:你只需一个 umi 依赖就可启动开发,无需安装 react、preact、webpack、react-router、babel、jest 等等。
-
约定式路由:类 next.js 的约定式路由,无需再维护一份冗余的路由配置,支持权限、动态路由、嵌套路由等等。
前端 UI 组件库
阿里前端 UI 组件库包括:- Ant Design - 前端中后台 React UI 组件库。
- Element - 前端中后台 Vue UI 组件库。
- AntV - 数据可视化组件库。
- …
Ant Design
Ant Design 服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。
Ant Design 不仅仅是一套组件库,而且还是一种设计语言,基于『确定』和『自然』的设计价值观,通过模块化的解决方案,降低冗余的生产成本,让设计者专注于更好的用户体验。
Ant Design 基于 React 框架,提供了总共 63 个 UI 组件,涵盖各种基本交互元素,例如按钮、布局、数据录入、数据展示等等。
Element
Element 是饿了么团队基于 Vue 打造的一套 UI 组件库,基于一致、反馈、效率、可控的设计原则。和 Ant Design 类似,它也提供了丰富的组件,并且提供了样式主题配置化以及国际化等功能。
Element 和 Ant Design 几乎已经成为中后台前端的标准 UI 组件库,往往根据不同的技术栈配合使用。Ant Design 往往配合 React 进行使用,而 Element 则会配合 Vue 进行使用。
AntV
AntV 3.0 已全新升级,主要包含 G2、G6、F2、L7 以及一套完整的图表使用和设计规范。得益于丰富的业务场景和用户需求挑战,AntV 经历多年积累与不断打磨,已支撑阿里集团内外 6000+ 业务系统。
AntV 作为数据可视化的组件库,从简单的线图到流程图,再到地理空间图应有尽有。下面给大家看几个例子:
跨平台
移动端跨平台、动态化始终是一个永恒不变的挑战,阿里巴巴作为电商平台也拥有众多 App,因此其在跨平台方面有非常丰富的尝试。首先就是基于 Vue 的 Weex 跨端解决方案,这是一个完全对标 React Native 的方案,在阿里淘系内部得到了大量实践。最近一年,闲鱼技术团队大量采用 Flutter,同时也沉淀了大量实践,开源了不少 Flutter 相关项目。
Weex
和 RN 的设计理念非常类似,通过 Vue 进行 UI 代码的编写,然后通过 Virtual Dom 转换成原生组件进行渲染,从而达到 Web 开发的体验和原生的渲染体验,而且也实现了跨 iOS、Android、Web 三端,极大地提升了研发效率。
但是,Weex 一度外界认为被阿里废弃,开源社区相对 RN 也不够活跃,所以让很多人望而却步。不过,最近 Weex 被 Apache 社区接纳,似乎重新焕发了青春。
Flutter
作为过去一年的当红炸子鸡,Flutter 的出现让跨平台的技术方案又出现一个完全不一样的思路。
Flutter 完全摒弃了 iOS/Android 的 UI 层,基于 C/C++ 自己实现了一套 UI 渲染引擎,在引擎之上,基于 Dart 语言实现了完整的 UI 框架。由于 Flutter 自己完全实现了一整套 UI 框架和底层渲染引擎,所以开发者基于这套框架可以完全实现跨端能力,并且也能获得非常良好的渲染体验。
闲鱼团队在其 App 中大量实践 Flutter 并且开源了 Flutter Boost、Fish Redux 等项目。
Flutter Boost
FlutterBoost 是一个 Flutter 插件,它可以轻松地为现有原生应用程序提供 Flutter 混合集成方案。FlutterBoost 的理念是将 Flutter 像 Webview 那样来使用。在现有应用程序中同时管理 Native 页面和 Flutter 页面并非易事。FlutterBoost 帮你处理页面的映射和跳转,你只需关心页面的名字和参数即可(通常可以是 URL)。
Flutter Redux
Fish Redux 通过 Redux 做集中化、可观察的数据管理。然而不仅于此,对于传统 Redux 在使用层面上的缺点,在面向端侧 flutter 页面维度开发的场景中,我们通过更好更高的抽象,做了改良。
State、Action、Reducer、Store、Middleware 以上概念和社区的 ReduxJS 是完全一致的,我们将原汁原味地保留所有的 Redux 的优势。
工程化智能化
阿里前端技术委员会圆心曾经分享过前端过去的发展历程,2016 年后前端进入到中后台重塑的时代,从原有的 Pro Code 逐步演进到 Low/No Code。玉伯曾经也展望过前端未来发展的趋势:人工化 -> 工具化 -> 工程化 -> 智能化。随着人工智能技术的加持,前端进入了一个全新的时代。
首先,聊聊阿里在前端工程化的发展。随着前端的系统架构越来越复杂,技术栈也越来越多样,对于大型研发团队而言,工程化可以在技术栈标准化、研发效率、质量提升等方面起到极大的作用。
WebIDE
所谓 WebIDE 就是只需要一个浏览器,就能够让你编写代码、运行代码,甚至发布代码。
WebIDE 有几个好处:- 无需本地安装 IDE。
- 无需关注本地环境,例如环境变量、npm 设置等等。
- 多人协同编辑,结对编程变得更加有趣。
- 可以打通现有工程化的能力,深入集成脚手架、工程模板、可视化组件编程、编译、打包、部署等等。
云构建
本地构建存在许多问题,例如依赖本地机器性能效率低下、构建工具不统一、本地环境不统一等等。因此,阿里基于 Docker 虚拟机搭建前端系统构建环境,解决了环境不一致和构建性能低的问题,同时还提供了完备的灰度管理、实时日志的能力。
在阿里内部,云构建目前日活跃用户有 1500+,日构建量 5w+,物理机器 20+,使用量还是非常大的,而且覆盖研发团队也非常广泛。
智能化 - imgcook
imgcook 可以实现从设计 (design) 到代码 (code) 的转换,目前可以支持 sketch、psd 和 JPG 文件。全链路采用计算机视觉、深度学习等智能化手段依次去除对设计稿的约束,通过对 Font 字体识别、Iconfont 图标识别、Layout 布局识别,智能生成代码,保证代码和视觉的高度还原。同时支持多种 DSL 代码生成,支持小程序、H5、Rax、Weex 等框架。
Ant Design Next
基于 Ant Design 的设计规范和组件库,阿里对中后台前端研发实现了一套 low code 的方式。
-
可视化、低代码:通过可视化拖拽界面生成页面代码,自动生成 css 文件完成布局,并且通过封装实现数据绑定、发送请求等操作,简化 JS 的编写。
-
提高效率:基于 REST API 接口定义,自动生成 CRUD 页面,完成 80% 业务场景。
-
提升体验:通过设计规范提高页面布局规范,同时减少页面组件渲染提升页面性能,通过也会对构建进行大量优化,默认沉淀大量最佳实践。
from https://www.infoq.cn/article/oogbsK28J411rxdkGIXV
相关推荐
问题描述: 停车场内只有一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列(大门在最南端,最先到达的第一辆车停放在停车场的最北端),若车场内已停满n辆汽车,则后来的汽车只能在门外的便道上等候,一旦有车开走,则排在便道上的第一辆车即可开入; 当停车场内某辆车要离开时,在它之后开入的车辆必须先退出车场为它让路,待该辆车开出大门外,其它车辆再按原次序进入车场,每辆停放在车场的车在它离开停车场时必须按它停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。 1.基本要求 (1)以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入的输入数据序列进行模拟管理。 (2)每一组输入数据包括三个数据项:汽车“到达”或“离去”信息、汽车牌照号码及到达或离去的时刻,对每一组输入数据进行操作后的输出数据为:若是车辆到达,则输出汽车在停车场内或便道上的停车位置;若是车离去;则输出汽车在停车场内停留的时间和应交纳的费用(在便道上停留的时间不收费)。 (3)栈以顺序结构实现,队列以链表实现。 2.重点难点 重点:针对停车场问题的特点,利
精选毕设项目-人民好公仆小程序(生活+便民+政务)
精选毕设项目-相册;处理用户信息
精选毕设项目-喵喵小说
精选毕设项目-图片预览带后端
精选项目-爱靓女带后台
在科技与司法的交响曲中,智慧法院应运而生,成为新时代司法服务的新篇章。它不仅仅是一个概念,更是对法院传统工作模式的一次深刻变革。智慧法院通过移动信息化技术,为法院系统注入了强大的生命力,有效缓解了案多人少的矛盾,让司法服务更加高效、便捷。 立案、调解、审判,每一个阶段都融入了科技的智慧。在立案阶段,智慧法院利用区块链技术实现可信存证,确保了电子合同的合法性和安全性,让交易双方的身份真实性、交易安全性得到了有力见证。这不仅极大地缩短了立案时间,还为后续审判工作奠定了坚实的基础。在调解阶段,多元调解服务平台借助人工智能、自然语言处理等前沿技术,实现了矛盾纠纷的快速化解。无论是矛盾类型的多元化,还是化解主体的多元化,智慧法院都能提供一站式、全方位的服务,让纠纷解决更加高效、和谐。而在审判阶段,智能立案、智能送达、智能庭审、智能判决等一系列智能化手段的应用,更是让审判活动变得更加智能化、集约化。这不仅提高了审判效率,还确保了审判质量的稳步提升。 更为引人注目的是,智慧法院还构建了一套完善的执行体系。移动执行指挥云平台的建设,让执行工作变得更加精准、高效。执行指挥中心和信息管理中心的一体化应用,实现了信息的实时传输和交换,为执行工作提供了强有力的支撑。而执行指挥车的配备,更是让执行现场通讯信号得到了有力保障,应急通讯能力得到了显著提升。这一系列创新举措的实施,不仅让执行难问题得到了有效解决,还为构建诚信社会、保障金融法治化营商环境提供了有力支撑。智慧法院的出现,让司法服务更加贴近民心,让公平正义的阳光更加温暖人心。
西门子1200与3台台达DTK温控器通讯程序 功能:实现西门子1200 PLC对3台台达DTK温控器进行485通讯控制,在触摸屏上设定温度,读取温度 器件:西门子1200 1214DC DC DC.昆仑通态TPC7062Ti ,西门子KTP700 Basic PN,台达DTK 4848V12温控器。 说明:的是程序,带详细注释程序,西门子触摸屏程序,PLC设置和温控器设置,接线说明书。 #SIEMENS 西门子
机械设计电阻绕线焊线一体机sw18全套技术资料100%好用.zip
VB6编写的上位机源码,可实时显示曲线图,带有数据库,可以进行历史数据的保存 及 查看历史采集数据。
精选毕设项目-新浪读书
jQuery+Slick插件实现游戏人物轮播展示切换特效源码是一款通过背景图片的切换来显示不同的人物效果,轮播效果通过slick幻灯片插件来制作。效果非常棒,有需要的朋友可以直接下载使用,适应各大网站
精选毕设项目-地图查找附件
(蛐蛐voc数据)农作物病虫害识别目标检测数据集,VOC格式,蛐蛐数据集,纯手动标注,用来进行目标检测代码训练的数据。
MATLAB Simulink仿真模型 双馈风机并网频率控制仿真模型,利用下垂控制与惯性控制结合的综合惯性控制,实现电力系统的频率稳定,两台同步发电机组,具体参数可自行调节,频率波形比较可利用matlab工作区画出。
一、结题报告的类型及主要结构 结题报告是一种专门用于科研课题结题验收的实用性报告类文体,也叫研究报告。它是研究者在课题研究结束后对科研课题研究过程和研究成果进行客观、全面、实事求是的描述,是课题研究所有材料中最主要的材料,也是科研课题结题验收的主要依据。 一篇规范、合格的结题报告,需要回答好3个问题:一是“为什么要选择这项课题进行研究?”二是“这项课题是怎样进行研究的?”三是“课题研究取得哪些研究成果?” 基本结构大致包括以下部分: 第一个问题 “为什么要选择这项课题进行研究?” 1.课题提出的背景;2.课题研究的意义(包括理论意义和现实意义,这个部分也可以合并归入“课题提出的背景”部分);第二个问题“这项课题是怎样进行研究的?”3.文献综述;4.课题研究的理论依据;5.课题研究的目标;6.课题研究的主要内容;7.课题研究的对象;8.课题研究的方法;9. 课题研究的主要过程(研究的步骤); 除了第9部分外,从第1到第8部分在填报课题立项申报表、在制定课题研究方案、在开题报告中,都有要求,内容基本相同。到了撰写结题报告时,只须稍作适当修改就可以了。而第9部分,则需要通过对
内容概要:本文档重点讲述了网络安全应急响应的各项准备工作,涵盖了‘1+X’网络安全应急响应的职业技能等级证书概述、应急响应的基础知识、应急响应组织的建立、风险评估与改进、应急响应预案的制定以及详细的应急响应计划处置样例。文中详细介绍了各级职业技能的要求和任务,尤其关注如何未雨绸缪,制定完善的应急预案以应对潜在的网络安全风险;同时也探讨了如何在网络安全事件发生时,采取及时有效的应急处置措施。 适合人群:从事或有兴趣进入网络安全领域的从业人员,尤其是准备考取‘1+X’网络安全应急响应职业技能等级证书的相关人员。 使用场景及目标:帮助读者了解网络安全应急响应的基本概念及其在整个国家安全框架中的重要地位;指导读者学会如何建立健全高效的应急响应组织结构,如何进行全面的风险评估以及如何编制切实可行的应急预案;通过实例剖析,增强读者应对突发网络安全事件的能力。文档的目标在于提升读者在不同层面的专业技能,包括但不限于系统备份、日志分析、安全漏洞修复等方面的能力。 阅读建议:此文档结构清晰,内容详尽,非常适合有一定基础的技术从业者参考学习。建议读者逐章节深入了解,特别是关注自身岗位对应的技能细分类别。此外,结合实例深入理解和练习如何进行应急处置是非常有价值的,有助于提升自身的实战能力。
电动汽车动力系统匹配计算模型:输入整车参数及性能要求,一键生成驱动系统的扭矩功率峰值转速等参数。 2、整车动力经济性计算模型:包含NEDC WLTC CLTC工况,输入整车参数可生成工况电耗、百公里电耗、匀速工况续航、百公里电耗等信息。 实际项目中使用的计算仿真模型. 两个模型打包
chromedriver-linux64_122.0.6254.0
SRS构型七自由度冗余机械臂运动学建模全套matlab代码 代码主要功能: [1]. 基于臂角参数化方法求解机械臂在给定末端位姿和臂角下的关节角度; [2]. 求解机械臂在给定末端位姿下的有效臂角范围,有效即在该区间内机械臂关节角度不会超出关节限位; [3]. 以避关节限位为目标在有效臂角区间内进行最优臂角的选取,进而获取机械臂在给定末端位姿下的最优关节角度。 购前须知: 1. 代码均为个人手写,主要包含运动学建模全套代码; 2. 代码已经包含必要的注释; 包含原理推导文档,不包含绘图脚本以及urdf;