ReactNative实现 RSC Render 的解决方案

方案探索

在 React Native 中可以使用零 Bundle 大小的 React 服务器组件吗?

由于需要适应快速的产品模块发布请求,要求在App不发版的场景下,对首页的Banner进行动态更新。

当下RN所支持的热更新已经可以满足大部分需求,但是也存在两个问题

  • 强制更新影响用户体验
  • 静默更新不能及时触达

基于上述问题,我门需要一套类似服务端渲染(SSR)的方式来解决.

服务端渲染简单的可以理解成在服务端进行页面元素结构的下发(json 字符串),在前端对其解析生成对应的元素树。同样,如果使用字符串来呈现 React Native 视图,则可以创建 0kb JavaScript 的原生 React Server 组件(即不需要提前编译进客户端)。

实现

1. 定义支持渲染的前端组件

const ComponentEnum = {'View': View,'Text': Text,'Image': Image,'Button': Pressable,'TextInput': TextInput,
};

2.  定义组件树解析结构

// 组件
type Component {static type: stringprops: anychildren?: Component
}// 点击事件
type Press {"@clientFn": trueevent: stringpayload: any
}

3. 解析

Object.entries(props).reduce((acc, [key, value]) => {if (value['@clientFn']) {return {...acc,[key]: () => {if (isFunction(callbacks[value.event])) {callbacks[value.event](value.payload);}}}}return {...acc,[key]: value};
}, {});

 4. 创建

const ComponentView = ComponentEnum[type] ?? ComponentEnum['View'];return createElement(ComponentView,newProps,isArray(children) ? Children.map(children, (child) => configToComponent(child, callbacks)) : children);

5. 生成 

export default new Proxy({}, {get: function (target, key, receiver) {// first time: target[key] = undefined;if (typeof target[key] === 'undefined') {// return function, ...args => Component propsreturn function (...args) {const {data, ...props} = args[0];// data => server jsx// props => { buttonPress: [Function buttonPress]}return configToComponent(data, props);};} else {// cache componentreturn Reflect.get(target, key, receiver);}}
});

 6. 声明

<SC.HomeBannerdata={{type: 'Text',props: {style: {width: 100,height: 100,backgroundColor: '#f0f'},onPress: {"@clientFn": true,event: 'buttonPress',payload: "123"}},children: '123'}}buttonPress={(data) => console.log('button pressed', data)}
/>

缺陷

需要提前定义可支持的组件以及内置Function代码,例如埋点、点击事件的处理等。

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

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

相关文章

【C++类和对象】拷贝构造与赋值运算符重载

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

ES6的编程风格

ES6 提出了两个新的声明变量的命令&#xff1a;let和const。其中&#xff0c;let完全可以取代var&#xff0c;因为两者语义相同&#xff0c;而且let没有副作用。 var命令存在变量提升效用&#xff0c;let命令没有这个问题 if (true) {console.log(x); // ReferenceErrorlet x…

分布式搭载博客网站

一.运行环境&#xff1a; IP主机名系统服务192.168.118.128Server-WebLinuxWeb192.168.118.131Server-NFS-DNSLinuxNFS/DNS 二.基础配置 1. 配置主机名&#xff0c;hosts映射 [rootserver ~]# hostnamectl set-hostname Server-Web [rootserver ~]# hostname Server-Web [r…

【学习笔记】Python大数据处理与分析——数据预处理

一、数据清洗 1、唯一值与重复值 获取唯一值的方法是采用unique()函数&#xff0c;用于Series对象&#xff1a; s1 pd.Series([2, 3, 4, 1, 2, 5, 3, 6, 4, 9, 5, 3, 4, 2, 1, 2])print(s1.unique()) →[2 3 4 1 5 6 9] 但unique()函数不能用于DataFrame对象&#xff0c;而d…

DNS是TCP还是UDP

既使用TCP也使用UDP 1. 域名解析时用UDP 在大多数情况下&#xff0c;DNS请求使用UDP协议&#xff0c;因为UDP协议可以提供较高的效率和安全性&#xff0c;尤其是在查询的响应大小较小&#xff08;通常不超过512字节&#xff09;时。非可靠连接&#xff0c;因为传输的数据量小…

Word分节后,页码不连续、转PDF每节后多出空白页解决办法

1. 问题图例 废话少说&#xff0c;先上图&#xff1a; 2. 问题分析 问题分析&#xff1a;出现以上问题的原因可能有&#xff0c; 未链接到上一节页面布局中节的起始位置设置为[奇数页] 3. 解决问题 若为【1. 未链接到上一节】导致该问题出现&#xff0c;则我们需要选中页脚…

【QT教程】QML Web多媒体处理

QML Web多媒体处理 使用AI技术辅助生成 QT界面美化视频课程 QT性能优化视频课程 QT原理与源码分析视频课程 QT QML C扩展开发视频课程 免费QT视频课程 您可以看免费1000个QT技术视频 免费QT视频课程 QT统计图和QT数据可视化视频免费看 免费QT视频课程 QT性能优化视频免费看 免…

Chatgpt掘金之旅—有爱AI商业实战篇|品牌故事业务|(十六)

演示站点&#xff1a; https://ai.uaai.cn 对话模块 官方论坛&#xff1a; www.jingyuai.com 京娱AI 一、AI技术创业在品牌故事业务有哪些机会&#xff1f; 人工智能&#xff08;AI&#xff09;技术作为当今科技创新的前沿领域&#xff0c;为创业者提供了广阔的机会和挑战。随…

LeetCode题练习与总结:x 的平方根--69

一、题目描述 给你一个非负整数 x &#xff0c;计算并返回 x 的 算术平方根 。 由于返回类型是整数&#xff0c;结果只保留 整数部分 &#xff0c;小数部分将被 舍去 。 注意&#xff1a;不允许使用任何内置指数函数和算符&#xff0c;例如 pow(x, 0.5) 或者 x ** 0.5 。 示…

接口压力测试 jmeter--入门篇(一)

一 压力测试的目的 评估系统的能力识别系统的弱点&#xff1a;瓶颈/弱点检查系统的隐藏的问题检验系统的稳定性和可靠性 二 性能测试指标以及测算 【虚拟用户数】&#xff1a;线程用户【并发数】&#xff1a;指在某一时间&#xff0c;一定数量的虚拟用户同时对系统的某个功…

SpringBoot多数据源AOP(四)

SpringBoot多数据源之AOP&#xff08;四&#xff09; 1.自定义注解2.切面类3.使用注解 1.自定义注解 这里定义了一个注解WR&#xff0c;作用在方法和类上&#xff0c;同时注解中value的默认值为W Target({ElementType.METHOD, ElementType.TYPE}) Retention(RetentionPolicy.R…

OpenMesh 网格平均曲率计算

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 根据 Laplace-Beltrami 算子与平均曲率法向的关系: 又根据余切 Laplace-Beltrami 算子的定义: 其中 Ai 为该点邻域面积,取 Voronoi cell 面积如下: 得到

儿童悬吊训练系统都有哪些锻炼形式

儿童悬吊训练作为一种创新的儿童训练方法&#xff0c;旨在结合儿童的身心发展特点&#xff0c;通过儿童悬吊系统的巧妙运用&#xff0c;达到提升儿童各项功能能力的目的。治疗师在运用悬吊系统对儿童进行训练时&#xff0c;必须紧密结合儿童的发育规律与自身功能水平&#xff0…

PACNet CellNet(代码开源)|bulk数据作细胞分类,评估细胞命运性能的一大利器

文章目录 1.前言2.CellNet2.1CellNet简介2.2CellNet结果 3.PACNet3.1安装R包与加载R包3.2加载数据3.3开始训练和分类3.4可视化分类过程3.5可视化分类结果 4.细胞命运分类和免疫浸润比较 1.前言 今天冲浪看到一个细胞分类性能评估的R包——PACNet&#xff0c;它与转录组分析方法…

Prometheus + Grafana 搭建监控仪表盘

目标要求 1、需要展现的仪表盘&#xff1a; SpringBoot或JVM仪表盘 Centos物理机服务器&#xff08;实际为物理分割的虚拟服务器&#xff09;仪表盘 2、展现要求: 探索Prometheus Grafana搭建起来的展示效果&#xff0c;尽可能展示能展示的部分。 一、下载软件包 监控系统核心…

Spring Cloud Gateway集成聚合型Spring Boot API发布组件knife4j,增强Swagger

大家都知道&#xff0c;在前后端分离开发的时代&#xff0c;前后端接口对接是一项必不可少的工作。 可是&#xff0c;作为后端开发&#xff0c;怎么和前端更好的配合&#xff0c;才能让自己不心累、脑累&#xff0c;直接扔给前端一个后端开放api接口文档或者页面&#xff0c;让…

Unity之OpenXR+XR Interaction Toolkit快速监听手柄任意按键事件

前言 当我们开发一个VR时,有时希望监听一个手柄按键的点击事件,或者一个按钮的Value值等。但是每次有可能监听的按钮有不一样,有可能监听的值不一样,那么每次这么折腾,有点累了,难道就没有一个万能的方法,让我可以直接监听我想要的某个按钮的事件么? 答案是肯定的,今…

Android --- 布局与点击事件

View&#xff08;视图) 此类代表用户界面组件的基本构建块。视图占据屏幕上的一个矩形区域&#xff0c;负责绘图和事件处理。View 是widgets的基类&#xff0c;用于创建交互式 UI 组件&#xff08;按钮、文本字段等&#xff09;。 子类是布局ViewGroup的基类&#xff0c;布局是…

分类算法——朴素贝叶斯(四)

概率基础 1概率定义 概率定义为一件事情发生的可能性 扔出一个硬币&#xff0c;结果头像朝上 P(X)&#xff1a;取值在[0&#xff0c;1] 2女神是否喜欢计算案例 在讲这两个概率之前我们通过一个例子&#xff0c;来计算一些结果&#xff1a; 问题如下&#xff1a; 1、女神喜欢…

sql知识总结二

一.报错注入 1.什么是报错注入&#xff1f; 这是一种页面响应形式&#xff0c;响应过程如下&#xff1a; 用户在前台页面输入检索内容----->后台将前台输入的检索内容无加区别的拼接成sql语句&#xff0c;送给数据库执行------>数据库将执行的结果返回给后台&#xff…