当前位置: 首页 > news >正文

Flutter 与 React 前端框架对比:深入分析与实战示例

Flutter 与 React 前端框架对比:深入分析与实战示例

在现代前端开发中,FlutterReact 是两个非常流行的框架。Flutter 是 Google 推出的跨平台开发框架,支持从一个代码库生成 iOS、Android、Web 和桌面应用;React 则是 Facebook 推出的基于 JavaScript 的前端框架,主要用于 Web 和 Native 开发。两者在开发方式、性能、生态系统等方面各有优劣,本文将从多个维度对它们进行详细对比,并通过具体代码示例展示它们的实际使用。


一、技术概览

1. Flutter
  • 语言:Dart
  • 核心特点
    • 提供丰富的内置组件(Material 和 Cupertino 风格)。
    • 完全自绘 UI,引擎渲染无需依赖平台组件。
    • 优秀的跨平台性能,一次编写,运行在多平台。
  • 使用场景
    • 移动端应用(iOS 和 Android)。
    • Web 应用和桌面应用。
    • 高性能、多动画效果的复杂应用。
2. React
  • 语言:JavaScript/TypeScript
  • 核心特点
    • 组件化开发,灵活性高。
    • 通过 Virtual DOM 提高 Web 性能。
    • 强大的生态系统,支持 React Native 实现跨平台。
  • 使用场景
    • 单页应用(SPA)。
    • 企业级 Web 前端系统。
    • 通过 React Native 开发移动端应用。

二、Flutter 与 React 对比

对比维度FlutterReact
开发语言Dart,类型安全,语法类似 Java 和 C#。JavaScript/TypeScript,动态语言,广泛使用。
性能接近原生性能,无需桥接,渲染引擎直接操作硬件。性能较好,但需要通过 JavaScript 桥接与 Native 通信。
跨平台能力支持 iOS、Android、Web、桌面(Windows、macOS、Linux)。React Native 支持 iOS 和 Android,但 Web 需单独开发。
学习曲线需要学习 Dart 和 Flutter 特定的概念,初学者稍有门槛。熟悉 JavaScript 的开发者上手容易,但需学习 React 的 JSX 和 Hook。
生态系统官方组件丰富,但生态相对 React 较小,插件选择稍有限。生态强大,拥有庞大的社区支持和第三方库。
UI 定制能力全自绘引擎,UI 定制能力强,适合打造高度一致的跨平台设计。使用平台原生组件,UI 一致性依赖于平台本身。

三、代码实战:构建一个计数器应用

为了更直观地对比 Flutter 和 React 的开发方式,我们分别使用两种框架构建一个简单的计数器应用。

1. Flutter 示例
import 'package:flutter/material.dart';void main() => runApp(MyApp());class MyApp extends StatelessWidget {Widget build(BuildContext context) {return MaterialApp(title: 'Flutter Counter',theme: ThemeData(primarySwatch: Colors.blue),home: CounterPage(),);}
}class CounterPage extends StatefulWidget {_CounterPageState createState() => _CounterPageState();
}class _CounterPageState extends State<CounterPage> {int _counter = 0;void _incrementCounter() {setState(() {_counter++;});}void _decrementCounter() {setState(() {_counter--;});}Widget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text('Flutter Counter')),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: [Text('You have pressed the button this many times:'),Text('$_counter',style: TextStyle(fontSize: 48, fontWeight: FontWeight.bold),),Row(mainAxisAlignment: MainAxisAlignment.center,children: [ElevatedButton(onPressed: _decrementCounter,child: Text('-'),),SizedBox(width: 16),ElevatedButton(onPressed: _incrementCounter,child: Text('+'),),],),],),),);}
}

运行该应用后,你会看到一个计数器页面,用户可以点击按钮增加或减少计数值。


2. React 示例

React 示例同样实现一个计数器功能。

import React, { useState } from 'react';function App() {const [counter, setCounter] = useState(0);const incrementCounter = () => {setCounter(counter + 1);};const decrementCounter = () => {setCounter(counter - 1);};return (<div style={{ textAlign: 'center', marginTop: '50px' }}><h1>React Counter</h1><p>You have pressed the button this many times:</p><h2 style={{ fontSize: '48px', fontWeight: 'bold' }}>{counter}</h2><div><button onClick={decrementCounter} style={{ marginRight: '10px' }}>-</button><button onClick={incrementCounter}>+</button></div></div>);
}export default App;

运行该代码需要安装 create-react-app 创建的开发环境,然后运行 npm start


四、两者的开发差异总结

1. 开发体验
  • Flutter 使用单一语言(Dart)统一处理业务逻辑和 UI,开发体验流畅,但对前端开发者来说需要一定的学习成本。
  • React 使用 JavaScript 开发,许多开发者已经熟悉其语法,生态丰富,但跨平台能力依赖 React Native。
2. UI 一致性
  • Flutter 拥有自定义的绘制引擎,保证跨平台的 UI 一致性。
  • React Native 使用原生组件,跨平台开发时 UI 表现可能略有差异。
3. 性能
  • Flutter 性能接近原生,尤其在复杂 UI 和动画场景中表现优秀。
  • React Native 性能稍逊,主要由于依赖 JavaScript 和原生桥接通信。

五、如何选择?

  • 选择 Flutter

    • 希望实现高性能、多平台一致的应用。
    • 对移动端和桌面应用有统一的开发需求。
    • 开发团队可以接受 Dart 语言和 Flutter 生态的学习成本。
  • 选择 React

    • 更熟悉 JavaScript 语言和 Web 开发生态。
    • 开发单页应用或前端界面为主的项目。
    • 希望利用现有的 Web 技术栈快速开发。

六、总结

Flutter 和 React 都是非常强大的前端框架,各有特色。Flutter 在跨平台性能和一致性上表现出色,而 React 拥有强大的生态系统和灵活性。开发者应根据项目需求、团队技术栈以及目标平台选择合适的框架。

无论选择哪种框架,掌握其特性和最佳实践,都是高效开发的关键。希望本文对你在 Flutter 和 React 的选择上有所帮助!如果有问题或建议,欢迎评论交流。

相关文章:

Flutter 与 React 前端框架对比:深入分析与实战示例

Flutter 与 React 前端框架对比&#xff1a;深入分析与实战示例 在现代前端开发中&#xff0c;Flutter 和 React 是两个非常流行的框架。Flutter 是 Google 推出的跨平台开发框架&#xff0c;支持从一个代码库生成 iOS、Android、Web 和桌面应用&#xff1b;React 则是 Facebo…...

基于Docker的Spark分布式集群

目录 1. 说明 2. 服务器规划 3. 步骤 3.1 要点 3.2 配置文件 3.2 访问Spark Master 4. 使用测试 5. 参考 1. 说明 以docker容器方式实现apache spark计算集群&#xff0c;能灵活的增减配置与worker数目。 2. 服务器规划 服务器 (1master, 3workers) ip开放端口备注ce…...

Web 代理、爬行器和爬虫

目录 Web 在线网页代理服务器的使用方法Web 在线网页代理服务器使用流程详解注意事项 Web 请求和响应中的代理方式Web 开发中的请求方法借助代理进行文件下载的示例 Web 服务器请求代理方式代理、网关和隧道的概念参考文献说明 爬虫的工作原理及案例网络爬虫概述爬虫工作原理 W…...

MySQL 事件调度器

MySQL 事件调度器确实是一个更方便且内置的解决方案&#xff0c;可以在 MySQL 服务器端自动定期执行表优化操作&#xff0c;无需依赖外部工具或应用程序代码。这种方式也能减少数据库维护的复杂性&#xff0c;尤其适用于在数据库频繁更新或删除时进行自动化优化。 使用 MySQL …...

直线拟合例子 ,岭回归拟合直线

目录 直线拟合,算出离群点 岭回归拟合直线&#xff1a; 直线拟合,算出离群点 import cv2 import numpy as np# 输入的点 points np.array([[51, 149],[122, 374],[225, 376],[340, 382],[463, 391],[535, 298],[596, 400],[689, 406],[821, 407] ], dtypenp.float32)# 使用…...

Flutter android debug 编译报错问题。插件编译报错

下面相关内容 都以 Mac 电脑为例子。 一、问题 起因&#xff1a;&#xff08;更新 Android studio 2024.2.2.13、 Flutter SDK 3.27.2&#xff09; 最近 2025年 1 月 左右&#xff0c;我更新了 Android studio 和 Flutter SDK 再运行就会出现下面的问题。当然 下面的提示只是其…...

关于IPD流程的学习理解和使用

IPD&#xff08;Integrated Product Development&#xff0c;集成产品开发&#xff09;是一种系统化的产品开发流程和方法论&#xff0c;旨在通过跨职能团队的协作和并行工程&#xff0c;缩短产品开发周期&#xff0c;提高产品质量&#xff0c;降低开发成本。IPD 最初由美国 PR…...

C# 类(Class)

C# 类&#xff08;Class&#xff09; 概述 在C#编程语言中&#xff0c;类&#xff08;Class&#xff09;是面向对象编程&#xff08;OOP&#xff09;的核心概念之一。类是一种用户定义的数据类型&#xff0c;它包含了一组属性&#xff08;数据&#xff09;和方法&#xff08;…...

Jenkins pipline怎么设置定时跑脚本

目录 示例&#xff1a;在Jenkins Pipeline中设置定时触发 使用pipeline指令设置定时触发 使用Declarative Pipeline设置定时触发 使用Scripted Pipeline设置定时触发 解释Cron表达式 保存和应用配置 小结 在Jenkins中&#xff0c;定时跑脚本&#xff08;例如定时执行Pip…...

PostgreSQL模糊查询相关学习参考

PostgreSQL大数据量快速模糊检索实践_postgresql 模糊查询-CSDN博客文章浏览阅读1.5k次&#xff0c;点赞20次&#xff0c;收藏25次。注意&#xff1a; 本文内容于 2024-08-18 23:50:33 创建&#xff0c;可能不会在此平台上进行更新。。_postgresql 模糊查询https://blog.csdn.n…...

【电脑无法通过鼠标和键盘唤醒应该怎么办】

【电脑无法通过鼠标和键盘唤醒应该怎么办】 方法一(有时候不起作用):方法二(方法一无效时,使用方法二): 方法一(有时候不起作用): 方法二(方法一无效时,使用方法二):...

Java 大视界 -- Java 大数据中的数据脱敏技术与合规实践(60)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…...

Vue3.5 企业级管理系统实战(三):页面布局及样式处理 (Scss UnoCSS )

本章主要是关于整体页面布局及样式处理&#xff0c;在进行这一章代码前&#xff0c;先将前两章中的示例代码部分删除&#xff08;如Home.vue、About.vue、counter.ts、App.vue中引用等&#xff09; 1 整体页面布局 页面整体布局构成了产品的框架基础&#xff0c;通常涵盖主导…...

【xcode 16.2】升级xcode后mac端flutter版的sentry报错

sentry_flutter 7.11.0 报错 3 errors in SentryCrashMonitor_CPPException with the errors No type named terminate_handler in namespace std (line 60) and No member named set_terminate in namespace std 替换sentry_flutter版本为&#xff1a; 8.3.0 从而保证oc的…...

windows在命令行中切换盘符

一、问题描述 我们在使用windows的cmd&#xff08;命令行&#xff09;时&#xff0c;经常需要用cd命令在不同盘之间切换路径。但有时在不同盘之间切换时&#xff0c;会发现命令不起作用。 如下图所示&#xff0c;直接切换目录还是停留在原来的位置。 二、解决方法 首先切换盘符…...

亚博microros小车-原生ubuntu支持系列:11手指控制与手势识别

识别框架还是沿用之前的了MediaPipe Hand。 背景知识不摘重复&#xff0c;参见之前的&#xff1a;亚博microros小车-原生ubuntu支持系列&#xff1a;10-画笔-CSDN博客 手指控制 src/yahboom_esp32_mediapipe/yahboom_esp32_mediapipe/目录下新建文件10_HandCtrl.py&#xff…...

JAVA-快速排序

目录 一、快速排序基本思想 二、快速排序的实现 1.Hoare法找基准值 2.挖坑法 3.前后指针法(了解) 三、快速排序的优化 1.三数取中法 2.递归到小的子区间时&#xff0c;可以考虑使用插入排序 四、非递归的写法 五、时间空间复杂度 一、快速排序基本思想 快速排序是 H…...

日志收集Day003

1.索引模板 查看所有索引模板 GET 10.0.0.101:9200/_template 2.查看单个索引模板 GET 10.0.0.101:9200/_template/.monitoring-es 3.创建索引模板 POST 10.0.0.101:9200/_template/lxctp {"aliases": {"DBA": {},"SRE": {},"K8S&qu…...

基于quartz,刷新定时器的cron表达式

文章目录 前言基于quartz&#xff0c;刷新定时器的cron表达式1. 先看一下测试效果2. 实现代码 前言 如果您觉得有用的话&#xff0c;记得给博主点个赞&#xff0c;评论&#xff0c;收藏一键三连啊&#xff0c;写作不易啊^ _ ^。   而且听说点赞的人每天的运气都不会太差&…...

数学大模型MAmmoTH:通过混合说明调整建立数学通才模型

向悦和陈文虎是该项目的主要作者。他们这个项目推出 MAmmoTH&#xff0c;这是一系列专为解决一般数学问题而定制的开源大型语言模型 (LLM)。 MAmmoTH 模型在 MathInstruct 上进行训练&#xff0c;MathInstruct 是我们精心策划的指令调整数据集。 MathInstruct 已编译 来自 13 个…...

19c补丁后oracle属主变化,导致不能识别磁盘组

补丁后服务器重启&#xff0c;数据库再次无法启动 ORA01017: invalid username/password; logon denied Oracle 19c 在打上 19.23 或以上补丁版本后&#xff0c;存在与用户组权限相关的问题。具体表现为&#xff0c;Oracle 实例的运行用户&#xff08;oracle&#xff09;和集…...

DeepSeek 赋能智慧能源:微电网优化调度的智能革新路径

目录 一、智慧能源微电网优化调度概述1.1 智慧能源微电网概念1.2 优化调度的重要性1.3 目前面临的挑战 二、DeepSeek 技术探秘2.1 DeepSeek 技术原理2.2 DeepSeek 独特优势2.3 DeepSeek 在 AI 领域地位 三、DeepSeek 在微电网优化调度中的应用剖析3.1 数据处理与分析3.2 预测与…...

shell脚本--常见案例

1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件&#xff1a; 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...

LeetCode - 394. 字符串解码

题目 394. 字符串解码 - 力扣&#xff08;LeetCode&#xff09; 思路 使用两个栈&#xff1a;一个存储重复次数&#xff0c;一个存储字符串 遍历输入字符串&#xff1a; 数字处理&#xff1a;遇到数字时&#xff0c;累积计算重复次数左括号处理&#xff1a;保存当前状态&a…...

工程地质软件市场:发展现状、趋势与策略建议

一、引言 在工程建设领域&#xff0c;准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具&#xff0c;正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...

(二)原型模式

原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...

镜像里切换为普通用户

如果你登录远程虚拟机默认就是 root 用户&#xff0c;但你不希望用 root 权限运行 ns-3&#xff08;这是对的&#xff0c;ns3 工具会拒绝 root&#xff09;&#xff0c;你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案&#xff1a;创建非 roo…...

大模型多显卡多服务器并行计算方法与实践指南

一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...

NFT模式:数字资产确权与链游经济系统构建

NFT模式&#xff1a;数字资产确权与链游经济系统构建 ——从技术架构到可持续生态的范式革命 一、确权技术革新&#xff1a;构建可信数字资产基石 1. 区块链底层架构的进化 跨链互操作协议&#xff1a;基于LayerZero协议实现以太坊、Solana等公链资产互通&#xff0c;通过零知…...

前端开发面试题总结-JavaScript篇(一)

文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包&#xff08;Closure&#xff09;&#xff1f;闭包有什么应用场景和潜在问题&#xff1f;2.解释 JavaScript 的作用域链&#xff08;Scope Chain&#xff09; 二、原型与继承3.原型链是什么&#xff1f;如何实现继承&a…...