flutter、tauri、maui你更看好哪一个?

哈喽,我是老刘

我们团队使用Flutter已经5年多了,当时选择Flutter的时候也是做了一些各个框架的对比的

不过那时候没有对比过Tauri

所以这里先说说Tauri,然后对比Flutter和Maui

Tauri

如果我的信息没有太过滞后的话

Tauri 目前支持移动端的V2版本还是beta阶段

那来看Tauri的架构,其实就是UI层面通过系统Native提供的功能去渲染网页

底层调用系统功能则是通过Rust实现

所以其实它的架构和Electron是最接近的,可以看作是对标

正式发布后的效果如何还要看正式版的优化和生态

不过从目前的架构来看

在手机端我觉得性能很难做到太好

因为它很难突破网页的性能限制

那么接下来看看Flutter和Maui的对比

Flutter vs MAUI

MAUI的架构

和RN其实很类似

MAUI的控件,最终在各个平台上会调用原生的系统控件

由系统控件完成最后的展示和渲染

而C#开发的代码作为业务逻辑的中间层

看下面这个按钮的实现

这种架构的好处是上层框架可以不用考虑各个平台的渲染问题

但是也带来了以下两个问题:

1、 平台一致性、兼容性不够好

这点其实很好理解

既然UI绘制最终交给了各平台的原生控件

那么如何保证一个上层控件的功能,在不同平台的原生控件上都有对应的实现?

如果一个功能在某些平台上有某些平台上没有怎么办?

而一旦在原生控件部分产生bug

那么开发人员就必须要回到原生代码层面进行定位和解决

这就进一步造成了碎片化和兼容性问题

2、 存在一定的性能损耗

这个问题我举个例子进行说明

比如我们要实现一个拖拽功能

就是在屏幕上点住一个元素,然后拖拽到屏幕其它地方

而且元素在屏幕的不同位置要显示不同的颜色

那这个代码如果在上层框架部分实现

就需要元素在屏幕上每移动一个像素

都从原生传递一个移动事件给上层框架

上层框架根据移动的位置计算颜色等显示信息

而这种大量的实时数据传输,会严重拖慢性能

那么再来看看Flutter架构,为什么Flutter没有类似的问题?

Flutter架构

Flutter最大的特点就是自带绘制引擎

也就是说Flutter抛弃了调用原生控件的思路

转而通过集成一个绘制引擎

把所有UI展示的工作自己实现了一遍

换个说法,Flutter相当于把原生UI替换掉了

这也就是为什么Flutter可以避免上面说的那些问题的原因

来看原生、MAUI和Flutter的架构对比

所以在目前的这种架构体系下

我更看好Flutter未来的发展

当然,如果Flutter的开发语言能换成C#那也是极好的

或者MAUI也集成一个渲染引擎也是很不错的方案

好了,关于几种跨平台框架的对比,就先介绍到这里

如果看到这里的同学有学习Flutter的兴趣,欢迎联系老刘,我们互相学习。

点击免费领老刘整理的《Flutter开发手册》,覆盖90%应用开发场景。

可以作为Flutter学习的知识地图。
覆盖90%开发场景的《Flutter开发手册》

相关推荐
renke336422 分钟前
Flutter for OpenHarmony:构建一个 Flutter 色彩调和师游戏,RGB 空间探索、感知色差计算与视觉认知训练的工程实现
flutter·游戏
王码码203530 分钟前
Flutter for OpenHarmony 实战之基础组件:第三十一篇 Chip 系列组件 — 灵活的标签化交互
android·flutter·交互·harmonyos
大空大地202641 分钟前
表达式与运算符
c#
向上的车轮1 小时前
为什么.NET(C#)转 Java 开发时常常在“吐槽”Java:checked exception
java·c#·.net
ujainu2 小时前
Flutter + OpenHarmony 实现经典打砖块游戏开发实战—— 物理反弹、碰撞检测与关卡系统
flutter·游戏·openharmony·arkanoid·breakout
微祎_2 小时前
构建一个 Flutter 点击速度测试器:深入解析实时交互、性能度量与响应式 UI 设计
flutter·ui·交互
王码码20352 小时前
Flutter for OpenHarmony 实战之基础组件:第二十七篇 BottomSheet — 动态底部弹窗与底部栏菜单
android·flutter·harmonyos
心疼你的一切3 小时前
Unity异步编程神器:Unitask库深度解析(功能+实战案例+API全指南)
深度学习·unity·c#·游戏引擎·unitask
ZH15455891313 小时前
Flutter for OpenHarmony Python学习助手实战:Web开发框架应用的实现
python·学习·flutter
晚霞的不甘3 小时前
Flutter for OpenHarmony 构建简洁高效的待办事项应用 实战解析
flutter·ui·前端框架·交互·鸿蒙