2019-2021 美团技术年货 前端篇
也是难以估量的。因此,通过打造一套 合适的跨端框架,以相对低的成本移植应用到鸿蒙平台,并利用好该系统的特性能 力,就成为了一个非常重要的选项。 在现有的众多跨端框架当中,Flutter 以其自渲染能力带来的多端高度一致性,在新 系统的适配上有着突出的优势。虽然 Flutter 官方并没有适配鸿蒙的计划,但经过一 段时间的探索和实践,美团外卖 MTFlutter 团队成功实现了 Flutter 的三层结构: 在 Flutter 的架构设计中,最上层为框架层,使用 Dart 语言开发,面向 Flutter 业务 的开发者;中间层为引擎层,使用 C/C++ 开发,实现了 Flutter 的渲染管线和 Dart 运行时等基础能力;最下层为嵌入层,负责与平台相关的能力实现。显然我们要做的 是将嵌入层移植到鸿蒙上,确切地说,我们要通过鸿蒙原生提供的平台能力,重新实 前端 < 3 现一遍 Flutter 嵌入层 要求的所有子模块,而从能力支持角度,渲染、交互以及其他必要的原生平台能力 是保证 Flutter 应用能够运行起来的最基本的要素,需要优先支持。接下来会依次进 行介绍。 1. 渲染流程打通 我们再来回顾一下 Flutter 的图像渲染流程。如图所示,设备发起垂直同步(VSync) 信号之后,先经过 UI 线程的渲染管线(Animate/Build/Layout/Paint),再经过0 码力 | 738 页 | 50.29 MB | 1 年前3JavaScript极速入门 —— 内核与引擎
最初内核的概念包括渲染引擎与JS引擎,目前习惯直接称渲染引擎为内核,JS引擎独立。 浏览器内核 渲染引擎 JavaScript引擎 最初状态 浏览器内核 渲染引擎 JavaScript引擎 目前状态 JavaScript引擎独立了 渲染引擎与JavaScript 引擎 渲染引擎:Rendering Engine,一般习惯将之称为“浏览器内核”,主要功能是解析HTML/CSS进 行渲染页面,渲 拟机、解释器,用来解释执行js代码。在早期内 核也是包含js引擎的,而现在js引擎越来独立了,可以把它单独提出来。 总结:渲染引擎(浏览器内核)处理html/css,JavaScript引擎处理JavaScript代码,有js引擎的 地方就能解析js代码 浏览器 渲染引擎(内核) 解析html/css JavaScript引擎 解析JavaScript代码 JavaScript和java什么关系0 码力 | 8 页 | 394.47 KB | 1 年前3前端开发者指南(2017)
请参看 platform.html5.org。 超文本标记语言 (HTML) 超文本标记语言,通常被称为 HTML,被用作创建网页的标准标记语言。网络浏览器可 以读取 HTML 文件并且把它们渲染成可见或可听的网页。HTML 在语义上描述了一个网 站的结构,并且隐含了其表现形式,因此是一种标记语言,而非程序语言。 — 维基百科 前端开发者所使用的技术 20 相关规范/文档: W3C 浏览器如何工作:现代浏览器的幕后原理 [阅读] 浏览器是如何真正渲染一个网站的? [观看] 什么会触发布局和重排 [阅读] 每位前端开发者必须知道的网页渲染技能 [阅读] 图片来源: http://www.html5rocks.com/en/tutorials/internals/howbrowserswork/ 浏览器优化 浏览器渲染优化 [观看] 网站性能优化 [观看] 对比浏览器 Web浏览器的比较 学习用户界面/交互设计 52 学习 HTML 和 CSS HTML —— 超文本标记语言,通常被称为 HTML, 是一种用于创建网页的标准标记语 言。 网页浏览器可以读取HTML文件并将其渲染成可视化网页。HTML 描述了网页的结 构语义,随着线索的呈现,使之成为标记语言而不是编程语言。 — 维基百科 CSS —— 层叠样式表 (CSS) 是一个层叠样式表语言,用来描述用标记语言来写的外观0 码力 | 164 页 | 6.43 MB | 1 年前3阮一峰 《ECMAScript 6入门》 第三版
JavaScript,因 此 type="application/javascript" 可以省略。 默认情况下,浏览器是同步加载 JavaScript 脚本,即渲染引擎遇到 3
Web 开发技术-JavaScript
标签才开始呈现内容。