写点什么

TikTok 原生跨平台 UI 框架 Lynx 宣布开源

  • 2025-04-05
    北京
  • 本文字数:1346 字

    阅读完需:约 4 分钟

TikTok 原生跨平台 UI 框架 Lynx 宣布开源

字节跳动宣布开源 Lynx 框架,这是一套支持使用 Web 标记语言、CSS 和 JavaScript 创建原生跨平台移动应用的开发工具集合。该框架通过自主研发的 JavaScript 引擎和像素级精准的 UI 渲染能力,实现原生级别的性能表现。


Lynx 架构师 Xuan Huang 解释称,Lynx 受 Chromium、Flutter 和 React Native 启发,意在通过应对日益复杂的设备形态差异和多平台支持需求,实现规模化且更高效的原生级体验。这些需求导致了“反复重建功能相同的模块,从而造成资源浪费、团队协作割裂,以及产品上市时间的延误”。


Lynx 框架延续了相似的设计理念——“专为应用开发定制的替代性 Web 方案”。该框架在继承 Web 技术优势的同时,采取了强约束策略:既支持类 Web API 接口,又通过施加特定限制与扩展来实现明确的设计意图。


为实现这一目标,Lynx 采用标记语言与 CSS 语法,让 Web 开发者得以进行移动应用开发。框架原生支持 CSS 动画与过渡效果、CSS 选择器与主题变量配置,以及渐变、遮罩、裁剪等现代 CSS 视觉效果。


在架构层面,Lynx 突破了传统 Web 单线程模型的限制,通过静态强制实施的双线程架构模型进行革新:主线程专用于处理高优先级的同步非阻塞任务,后台线程则负责执行用户代码。据 Huang 介绍,这种架构设计使得 Lynx 能够近乎即时地渲染应用的首帧界面,大幅优化"首帧渲染时间(TTFF)"指标,同时也通过在主线程高效处理高优先级事件与手势操作,确保界面交互的高响应度。


Lynx 框架由多个组件构成,其中包括:Lynx 核心引擎;基于 React 的声明式 UI 前端框架 ReactLynx;采用 Rust 语言构建的、基于 webpack 兼容的 Rspack 开发的高性能打包工具 Rspeedy;优化版 JavaScript 引擎 PrimJS;以及基于 Electron 的调试工具 Lynx DevTool。该框架还提供了 Web 前端适配层,支持在浏览器环境中运行 Lynx 应用。


在 Syntax FM 的技术播客中,字节跳动工程师 Zack Jackson 将 Lynx 定位为公司内部的 React 替代方案,这套框架驱动着其他所有应用程序的 UI 层,以确保跨团队技术架构的统一性。不过 Huang 在官方声明中特别强调,Lynx 并不局限于 React 技术栈,未来还会逐步开源其他前端方案。


目前该框架已应用于 TikTok 应用内的搜索框,以及专为创作者打造的内容生产和管理工具 TikTok Studio 等多个业务场景。


Hacker News 上自称就职于字节的用户 suzakus 透露,iOS 与安卓客户端中最重要的跨平台功能模块采用 C++ 编写以实现跨平台的可移植性,而其他包括大部分的 UI 组件仍使用 Kotlin 或 Swift 开发。这一技术现状虽看似与应用中 Lynx 框架的普及程度存在反差,但却是与 Huang 此前描述的渐进式演进路线相吻合。


此外,Huang 也在 Hacker News 的评论区回应了为何字节选择与现存最古老的命令行网页浏览器 重名:


Lynx 项目最初命名时并未考虑长远影响。鉴于已有大量代码库和用户依赖现有名称,我们决定保持原名,不因项目的开源而更名。


最后,Huang 强调说,字节跳动将持续推进 Lynx 框架的开源进程,未来将陆续公开更多 UI 组件、定制化渲染引擎及其他前端框架。该框架还将突破移动端限制,逐步扩展至桌面端、电视以及 IoT 设备等更多平台。


查看英文原文

TikTok’s Native Cross-Platform UI Framework Lynx Goes Open Source(https://www.infoq.com/news/2025/03/tiktok-lynx-cross-platform-apps/)

2025-04-05 10:009316

评论

发布
暂无评论

两个小女孩

箭上有毒

8月日更

Druid 加载 Kafka 数据时通过控制台来提交一个 supervisor

HoneyMoose

Vue进阶(十三):MOCK

No Silver Bullet

Vue Mock 8月日更

Druid 加载 Kafka 数据时直接提交一个 supervisor

HoneyMoose

oeasy教您玩转vim - 7 - # 从头插入

o

netty系列之:Event、Handler和Pipeline

程序那些事

Java Netty nio 程序那些事

🏆【Java技术之旅】「编译器专题」重塑认识Java编译器的执行过程(消除数组边界检查+公共子表达式)!

码界西柚

Java 编译器 8月日更 JIT编译器

深入了解NIO底层原理

陈皮的JavaLib

Java 面试 nio 8月日更

【设计模式】桥接模式

Andy阿辉

编程 后端 设计模式 8月日更

如何从 0 到 1 设计 B 端产品?

蒋川

后台开发 产品开发 后台 后台管理系统 tob产品

番外2. OpenCV 中摄像头捕获与视频处理与常见问题解决方案

梦想橡皮擦

8月日更

前端之数据结构(三)集合和字典

Augus

数据结构 8月日更

Linux中buff-cache占用过高解决方案

入门小站

Linux

Druid 使用 Kafka 数据加载教程——下载和启动 Kafka

HoneyMoose

有状态流处理简介(一)

Databri_AI

flink 批处理 状态

spring的循环依赖

卢卡多多

spring aop 8月日更

Druid 使用 Kafka 将数据载入到 Kafka

HoneyMoose

JavaScript代码片段学设计模式

devpoint

设计模式 工厂模式 8月日更

在线邮箱地址提取工具

入门小站

工具

超全激活函数学习总结!!!

Shirakawa

神经网络 机器学习 算法 激活函数

oeasy教您玩转vim - 9 - # 换行插入

o

kubernetes入门:harbor个人私有仓库傻瓜式搭建

小鲍侃java

8月日更

Vue进阶(十四):config/index.js 配置文件详解

No Silver Bullet

Vue 8月日更 配置文件

docker编排参数详解(docker-compose.yml配置文件编写)

xcbeyond

Docker 容器 8月日更

架构训练营 模块4作业

sophiahuxh

Druid 加载 Kafka 数据后查询和清理数据

HoneyMoose

数据探索

南湖职业技术学院机械狗

元数据管理服务分析报告

漫长的白日梦

数据湖 AWS 元数据

oeasy教您玩转vim - 8 - # 追加文本

o

【Flutter 专题】75 图解基本 TabBar 标签导航栏 (一)

阿策小和尚

Flutter 小菜 0 基础学习 Flutter Android 小菜鸟 8月日更

Go并发之CSP并发模型、协程并发

Regan Yue

协程 CSP Go 语言 8月日更

TikTok 原生跨平台 UI 框架 Lynx 宣布开源_架构_Sergio De Simone_InfoQ精选文章