Flutter / iOS 迁移鸿蒙 ArkUI 的真实成本

Flutter / iOS 迁移鸿蒙 ArkUI 的真实成本
在这里插入图片描述

子玥酱(掘金 / 知乎 / ZEEKLOG / 简书 同名)

大家好,我是子玥酱,一名长期深耕在一线的前端程序媛 👩‍💻。曾就职于多家知名互联网大厂,目前在某国企负责前端软件研发相关工作,主要聚焦于业务型系统的工程化建设与长期维护。

我持续输出和沉淀前端领域的实战经验,日常关注并分享的技术方向包括前端工程化、小程序、React / RN、Flutter、跨端方案,
在复杂业务落地、组件抽象、性能优化以及多端协作方面积累了大量真实项目经验。

技术方向:前端 / 跨端 / 小程序 / 移动端工程化
内容平台:掘金、知乎、ZEEKLOG、简书
创作特点:实战导向、源码拆解、少空谈多落地
文章状态:长期稳定更新,大量原创输出

我的内容主要围绕 前端技术实战、真实业务踩坑总结、框架与方案选型思考、行业趋势解读 展开。文章不会停留在“API 怎么用”,而是更关注为什么这么设计、在什么场景下容易踩坑、真实项目中如何取舍,希望能帮你在实际工作中少走弯路。

子玥酱 · 前端成长记录官 ✨
👋 如果你正在做前端,或准备长期走前端这条路
📚 关注我,第一时间获取前端行业趋势与实践总结
🎁 可领取 11 类前端进阶学习资源(工程化 / 框架 / 跨端 / 面试 / 架构)
💡 一起把技术学“明白”,也用“到位”

持续写作,持续进阶。
愿我们都能在代码和生活里,走得更稳一点 🌱

文章目录

引言

过去一年,很多团队都在讨论一件事:

要不要把现有 App 迁移到鸿蒙?

尤其是已经有成熟产品的团队,比如:

  • 原生 iOS
  • Android
  • Flutter
  • React Native

很多决策层的第一反应通常是:

“迁移成本大不大?”

很多人会简单地回答一句:

  • UI 要重写
  • 技术栈不同

但如果你真的做过迁移项目就会知道:

真正的成本,远远不止 UI。

从工程结构到开发模式,再到团队经验,
迁移鸿蒙 ArkUI,本质是一次架构级变化。

第一层成本:UI 重写

这是所有人第一时间想到的成本。

Flutter → ArkUI

Flutter UI 是:

Scaffold( appBar:AppBar(title:Text('订单')), body:ListView.builder( itemCount: orders.length, itemBuilder:(context, index){returnListTile( title:Text(orders[index].title),);},),);

ArkUI 写法:

@Entry@Component struct OrderPage {@State orders: Order[]=[]build(){Column(){List(){ForEach(this.orders,(item: Order)=>{ListItem(){Text(item.title)}})}}}}

虽然都是声明式 UI,但有三个明显差异:

  • 组件模型不同
  • 状态机制不同
  • 生命周期不同

所以 UI 基本无法复用

iOS → ArkUI

iOS SwiftUI:

List(orders){ order inText(order.title)}

ArkUI:

List(){ForEach(this.orders,(item: Order)=>{ListItem(){Text(item.title)}})}

语法很像,但:

  • SwiftUI 生命周期
  • ArkUI 状态驱动
  • 路由体系

仍然需要重构。

一个真实经验

很多团队最开始会以为:

“UI 迁移最多两个月。”

但实际情况往往是:

UI 重写只占迁移成本的 30% 左右。

真正复杂的在后面。

第二层成本:工程架构重构

Flutter / iOS 的工程结构,和鸿蒙完全不同。

Flutter 项目结构

lib/ pages/ widgets/ services/ models/ 

逻辑非常简单。

鸿蒙 App 结构

鸿蒙应用通常是:

entry/ src/ main/ ets/ pages/ components/ services/ models/ 

但更关键的是:

鸿蒙是 Ability 架构。

Ability 模型

import UIAbility from'@ohos.app.ability.UIAbility'exportdefaultclassEntryAbilityextendsUIAbility{onCreate(){console.log('App started')}}

这里意味着:

  • 生命周期不同
  • 页面管理不同
  • 系统能力调用不同

很多 Flutter 开发者第一次接触 Ability 时都会懵。

第三层成本:状态管理重写

Flutter 常见方案:

  • Provider
  • Riverpod
  • Bloc
  • GetX

示例:

classCounterProviderextendsChangeNotifier{ int count =0;voidincrement(){ count++;notifyListeners();}}

ArkUI 的状态机制是:

@State count:number=0Button('增加').onClick(()=>{this.count++})

但真正复杂的是跨组件状态。

ArkUI 数据共享

@Provide counter:number=0

子组件:

@Consume counter:number

这套机制和 Flutter 完全不同,迁移意味着:

所有状态管理逻辑都要重写。

第四层成本:插件与系统能力

Flutter 项目通常依赖大量插件。

例如:

  • camera
  • location
  • push
  • analytics

示例:

CameraController(camera,ResolutionPreset.medium)

迁移鸿蒙后:这些插件很多都不存在,必须调用系统能力。

鸿蒙系统能力

例如相机:

import camera from'@ohos.multimedia.camera'let cameras =await camera.getCameras()

定位:

import geolocation from'@ohos.geoLocation' geolocation.getCurrentLocation()

问题在于:

很多 Flutter 插件逻辑需要重新封装。

这部分往往是最大成本之一。

第五层成本:团队经验

技术迁移最容易被忽略的一点是:

团队学习成本。

例如 ArkTS。

Dart

var name ='Flutter'

ArkTS

let name:string='Harmony'

看起来很像 TypeScript,但鸿蒙开发还涉及:

  • DevEco Studio
  • Ability 生命周期
  • 分布式能力
  • 权限模型

团队从零熟悉这些,通常需要:

1-3 个月。

一个真实迁移成本模型

如果是一个中型 App,假设:

  • 20 个页面
  • 10 个核心模块
  • 15 个插件依赖

迁移成本大概是:

项目成本占比
UI 重写30%
工程结构调整20%
状态管理迁移15%
插件重写25%
团队学习10%

如何降低迁移成本

真正有经验的团队通常不会“全量重写”,而是采用渐进迁移。

第一阶段:核心模块迁移

只迁移:

  • 登录
  • 首页
  • 核心业务

其余继续保留原 App。

第二阶段:能力封装

把业务能力抽象为服务:

exportclassOrderService{asyncqueryOrders(){return http.get('/orders')}}

这样 UI 重写时逻辑不会动。

第三阶段:组件复用

建立组件库:

components/ CommonList Card Button 

统一 UI 逻辑。

一个重要结论

很多人问:

鸿蒙迁移值不值得?

答案其实不在技术,而在产品战略,如果你的 App 需要:

  • 全场景设备
  • 分布式协同
  • 系统级能力

那么迁移鸿蒙会带来新机会,但如果只是一个普通移动 App:

迁移更多是成本,而不是收益。

总结

Flutter / iOS 迁移鸿蒙 ArkUI 的真实成本,并不只是 UI 重写。

真正的成本来自五个方面:

  • UI 重写
  • 工程架构调整
  • 状态管理迁移
  • 插件与系统能力重构
  • 团队学习成本

所以迁移鸿蒙,本质上不是一次“代码迁移”,而是:

一次技术栈与工程模式的重构。

理解这一点,你才能真正评估迁移决策。

Read more

一文看懂:AI编程工具深度对比:Cursor、Copilot、Trae与Claude Code

一文看懂:AI编程工具深度对比:Cursor、Copilot、Trae与Claude Code

AI编程工具深度对比:Cursor、Copilot、Trae与Claude Code 引言 在人工智能技术蓬勃发展的今天,AI编程工具已成为开发者提高效率的重要助手。从早期的代码补全插件到如今能够理解整个代码库的智能助手,AI编程工具正在不断进化。本文将对当前主流的AI编程工具——Cursor、GitHub Copilot、Trae和Claude Code进行全面对比,帮助开发者选择最适合自己的工具。 主流AI编程工具概述 Cursor Cursor是一款基于VSCode的AI驱动代码编辑器,它最大的特点是能够理解整个代码库的上下文,提供智能的代码补全和重构建议。Cursor默认使用Claude-3.5-Sonnet模型,即使是OpenAI投资的公司,也选择了Claude模型作为默认选项,这足以说明其在代码生成领域的优势。 GitHub Copilot GitHub Copilot是由GitHub与OpenAI合作开发的AI编码助手,集成在VSCode、Visual Studio等主流编辑器中。它基于OpenAI的模型,能够根据注释和上下文自动生成代码,是AI编程工具

By Ne0inhk
AI 编程工具选型:Copilot、Cursor、Codex 核心差异

AI 编程工具选型:Copilot、Cursor、Codex 核心差异

【如文章引起大家共鸣,请“点赞”以及“转发”,以支持继续创作,谢谢大家!】 朋友们大家好!今天咱们不聊那些虚头巴脑的,直接来点实在的——AI编程工具选型,Copilot、Cursor、Codex这仨到底咋选?别急,我这就用最接地气的方式,给你唠唠它们的“脾气秉性”,保证你听完就能上手挑! 先说Copilot,这哥们儿可是“代码补全界的扛把子”!它就像你身边的“代码小秘书”,你敲代码时,它就在旁边默默观察,你刚敲个“for”,它立马给你补上“(int i=0;i<n;i++)”,那叫一个快!而且,它还支持多IDE,VS Code、JetBrains啥的,都能无缝对接。不过呢,Copilot也有个“小毛病”,就是它更擅长“补全”,对于复杂的代码重构或者项目级理解,就有点力不从心了。

By Ne0inhk
Qoder+Skills,一个人一周完成开源官网重构

Qoder+Skills,一个人一周完成开源官网重构

"你的官网,AI 能读懂吗?"当我第一次把 Higress 文档链接丢给 Claude,让它帮我写个接入 Demo 时,AI 的回复是:"抱歉,我无法有效解析这个页面的内容结构…"这一刻我意识到:我们的文档,正在被时代淘汰。 00 TL;DR * 🏗️ 技术栈大换血:迁移到 Astro 5 + Starlight,Lighthouse 性能跑分 100 分。 * 🤖 AI 友好:接入 llms.txt 标准,支持 Cursor、Claude Code 等 主流 AI Coding 工具。 * 🎯 AI 全能助手:

By Ne0inhk
在昇腾NPU上跑Llama 2模型:一次完整的性能测试与实战通关指南

在昇腾NPU上跑Llama 2模型:一次完整的性能测试与实战通关指南

目录 * 在昇腾NPU上跑Llama 2模型:一次完整的性能测试与实战通关指南 * 引言:从“为什么选择昇腾”开始 * 第一幕:环境搭建——好的开始是成功的一半 * 1.1 GitCode Notebook 创建“避坑指南” * 1.2 环境验证:“Hello, NPU!” * 第二幕:模型部署——从下载到运行的“荆棘之路” * 2.1 安装依赖与模型下载 * 2.2 核心部署代码与“坑”的化解 * 第三幕:性能测试——揭开昇腾NPU的真实面纱 * 3.1 严谨的性能测试脚本 * 3.2 测试结果与分析 * 第四幕:性能优化——让Llama跑得更快 * 4.1 使用昇腾原生大模型框架 * 4.

By Ne0inhk