做鸿蒙 App 一个月:10 个 ArkUI 大坑

做鸿蒙 App 一个月:10 个 ArkUI 大坑
在这里插入图片描述

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

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

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

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

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

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

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

文章目录

引言

最近一个月,我从传统 App(Android / Flutter)转向开发鸿蒙应用,用 ArkUI(ArkTS) 写了一个完整的项目。

一开始我以为:

“不就是一个声明式 UI 框架吗?”

但真正写下来才发现,ArkUI 的设计和传统 App 差别非常大

一个月下来,我踩了不少坑。

坑 1:状态没有用 @State,UI 不更新

很多刚写 ArkUI 的开发者,会这样写代码:

struct CounterPage { count:number=0build(){Column(){Text(`count: ${this.count}`)Button("Add").onClick(()=>{this.count++})}}}

你会发现:点击按钮 UI 不更新。

原因很简单:ArkUI 的 UI 是 响应式的,只有被声明为状态的变量才会触发刷新。

正确写法:

@Entry@Component struct CounterPage {@State count:number=0build(){Column(){Text(`count: ${this.count}`)Button("Add").onClick(()=>{this.count++})}}}

核心原则:

UI 依赖的数据必须是状态。

坑 2:组件参数忘记用 @Prop

很多人写组件时会这样写:

@Component struct UserCard { name:stringbuild(){Text(this.name)}}

在父组件使用:

UserCard({ name:"Tom"})

结果编译报错,原因是:ArkUI 的组件参数必须使用 @Prop 标记。

正确写法:

@Component struct UserCard {@Prop name:stringbuild(){Text(this.name)}}

如果参数会变化,可以用:

@Link 

@Observed 

坑 3:列表渲染性能问题

很多开发者第一次写列表会这样:

Column(){ForEach(this.list,(item)=>{Text(item.name)})}

如果列表很多:

  • UI 会卡顿
  • 滑动不流畅

因为 Column 会一次性渲染所有内容。正确做法:

使用 LazyForEach

List(){LazyForEach(this.list,(item)=>{ListItem(){Text(item.name)}})}

优势:

  • 按需渲染
  • 性能更好

坑 4:组件状态共享混乱

很多人一开始会滥用 @State,例如:

@State userInfo: User 

然后在多个组件之间传递,结果导致:

  • 状态同步混乱
  • UI 更新异常

正确做法是:使用 @Provide / @Consume,例如父组件:

@Provide userInfo: User ={ name:"Tom"}

子组件:

@Consume userInfo: User 

这样可以实现 跨组件状态共享

坑 5:生命周期理解错误

很多 Android / Flutter 开发者会寻找类似:

onCreate onResume 

这样的生命周期。ArkUI 其实提供了不同机制:

aboutToAppear(){console.log("页面即将出现")}aboutToDisappear(){console.log("页面消失")}

例如加载数据:

aboutToAppear(){this.loadData()}

坑 6:页面路由方式不同

很多开发者会寻找传统 Router,ArkUI 的导航方式是:

router.pushUrl() 

例如:

import router from'@ohos.router' router.pushUrl({ url:'pages/detail'})

返回:

router.back()

坑 7:UI 布局思维没转过来

很多 Android 开发者习惯:

LinearLayout RelativeLayout ConstraintLayout 

ArkUI 的布局更接近 Flexbox 思维,例如:

Row(){Text("Left")Blank()Text("Right")}

Blank() 相当于 flex spacer

坑 8:组件拆分不合理

很多人会写出一个 巨大的页面组件

struct HomePage {// 1000 行代码}

正确方式是 组件拆分

HomePage ├─ Banner ├─ UserInfo ├─ MenuGrid ├─ FeedList 

例如:

@Component struct Banner {build(){Text("Banner")}}

坑 9:动画系统不熟悉

ArkUI 内置动画非常简单:

.animateTo({ duration:300},()=>{this.scale =1.2})

例如点击放大:

Button("Click").onClick(()=>{animateTo({ duration:300},()=>{this.scale =1.2})})

坑 10:没有理解声明式 UI

这是 最核心的坑,很多开发者还在用 命令式思维

修改 UI 刷新 UI 重新渲染 UI 

而 ArkUI 的核心思想是:

UI = State

例如:

Text(this.isLogin ?"已登录":"未登录")

只需要改变状态:

this.isLogin =true

UI 会自动更新。

总结

写了一个月鸿蒙应用,我最大的感受是:ArkUI 的学习成本不在语法,而在思维。

你需要从:命令式 UI,转变为声明式 UI + 状态驱动 UI。理解这一点之后,很多问题都会迎刃而解。

如果你刚开始学习鸿蒙开发,建议重点理解三件事:

1️⃣ 状态管理
2️⃣ 声明式 UI 思维
3️⃣ 组件化设计

掌握这三点,ArkUI 会顺手很多。

Read more

Java 大视界 -- Java 大数据在智能教育学习资源智能分类与标签优化中的应用(346)

Java 大视界 -- Java 大数据在智能教育学习资源智能分类与标签优化中的应用(346)

Java 大视界 -- Java 大数据在智能教育学习资源智能分类与标签优化中的应用(346) * 引言: * 正文: * 一、Java 构建的全学科资源分类系统(含特殊教育适配) * 1.1 跨学科标签链生成(数学 / 语文案例) * 1.2 特殊教育资源处理(盲校 / 手语案例) * 1.3 标签动态迭代机制(用户行为驱动) * 二、实战案例:从课堂到特殊教育的资源革命 * 2.1 江苏中学数学组:课标标签链 * 2.2 某特殊教育学校:盲文资源导航 * 结束语: * 🗳️参与投票和联系我: 引言: 嘿,亲爱的 Java 和 大数据爱好者们,大家好!我是ZEEKLOG四榜榜首青云交!《2024 年中国智能教育发展报告》显示,

By Ne0inhk
告别 IDEA,拥抱 Trae:一位 Java 后端程序员的真实迁移体验

告别 IDEA,拥抱 Trae:一位 Java 后端程序员的真实迁移体验

作为一名常年和 Spring Boot、微服务打交道的 Java 开发者,IDEA 几乎是我过去几年的 “本命 IDE”。但最近,我彻底把主力开发环境换成了Trae。这不是跟风尝鲜,而是真实体验到效率、流畅度与 AI 能力的全面升级。 这篇文章,我用最实在的体验,告诉你Java 程序员从 IDEA 迁移到 Trae 到底值不值、怎么迁、踩过哪些坑、带来哪些爽点。 一、为什么我会从 IDEA 转向 Trae? 先说说我放弃 IDEA 的核心原因: 1. 启动慢、吃内存:项目稍大就卡,开机启动要等半天 2. 插件臃肿:很多功能用不上,却占资源 3. AI 能力弱:自带补全跟不上时代,装插件又不稳定

By Ne0inhk
Eclipse Compiler for Java (ECJ):安装指南与高效快捷键全解析

Eclipse Compiler for Java (ECJ):安装指南与高效快捷键全解析

🔥个人主页:@草莓熊Lotso 🎬作者简介:C++研发方向学习者 📖个人专栏: 《C语言》 《数据结构与算法》《C语言刷题集》《Leetcode刷题指南》 ⭐️人生格言:生活是默默的坚持,毅力是永久的享受。  前言:在 Java 开发领域,编译器是连接源代码与运行程序的核心桥梁。Eclipse Compiler for Java (ECJ) 作为 Eclipse IDE 的 “幕后功臣”,凭借增量编译速度快、错误提示实时性强、对Java 新特性支持及时等优势,成为众多开发者处理大型项目的首选工具。与 JDK 自带的 javac 相比,ECJ 更擅长处理频繁的代码修改 —— 当你在项目中仅修改一个类时,它只会重新编译受影响的文件,而非整个项目,这在动辄数万行代码的企业级开发中,能节省大量等待时间。本篇博客将从安装配置到快捷键使用,全方位带你掌握 ECJ 的实用技巧,让编译效率再上一个台阶。

By Ne0inhk
这5个开源量化AI炒股工具,让散户也能秒变量化大神!(附真实交易案例)

这5个开源量化AI炒股工具,让散户也能秒变量化大神!(附真实交易案例)

作 者:老余捞鱼 原创不易,转载请标明出处及原作者。 写在前面的话:"主力资金动向难捕捉""技术指标不会用""情绪化交易总亏钱"——这是90%散户的痛点。而量化交易就像给普通股民装上"AI外挂",让数据说话、让策略自动执行!今天揭秘5个免费开源的量化神器,手把手教你从零搭建自己的智能交易系统。 一、如何选择适合自己的量化炒股工具? 这两年炒股你被量化交易收割过吧?既然散户们打不过它,我建议还不如尽早加入它。 普通人用量化工具炒股,能自动化交易、避免情绪干扰,同时利用数据分析和策略回测提高胜率。 而开源工具免费、透明、可定制,比市面上销售的闭源软件更灵活可控,适合想科学投资、有一定动手能力的散户或刚刚起步的小投资团队,尤其适合需要自主掌控策略的投资者。 下面是本次给大家介绍的5款开源量化投资工具一览表。 工具名称难度系数最佳场景学习资源qlib⭐⭐⭐AI因子挖掘微软官方教程vn.py⭐⭐多账户套利B站实战视频rd-agent⭐⭐⭐⭐自动进化策略GitHub Issues讨论区abu⭐⭐⭐缠论+AI结合知乎专栏《

By Ne0inhk