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

鸿蒙游戏如何避免“巨型页面文件”?

子玥酱掘金 / 知乎 / CSDN / 简书 同名大家好我是子玥酱一名长期深耕在一线的前端程序媛 ‍。曾就职于多家知名互联网大厂目前在某国企负责前端软件研发相关工作主要聚焦于业务型系统的工程化建设与长期维护。我持续输出和沉淀前端领域的实战经验日常关注并分享的技术方向包括前端工程化、小程序、React / RN、Flutter、跨端方案在复杂业务落地、组件抽象、性能优化以及多端协作方面积累了大量真实项目经验。技术方向前端 / 跨端 / 小程序 / 移动端工程化内容平台掘金、知乎、CSDN、简书创作特点实战导向、源码拆解、少空谈多落地文章状态长期稳定更新大量原创输出我的内容主要围绕前端技术实战、真实业务踩坑总结、框架与方案选型思考、行业趋势解读展开。文章不会停留在“API 怎么用”而是更关注为什么这么设计、在什么场景下容易踩坑、真实项目中如何取舍希望能帮你在实际工作中少走弯路。子玥酱 · 前端成长记录官 ✨ 如果你正在做前端或准备长期走前端这条路 关注我第一时间获取前端行业趋势与实践总结 可领取11 类前端进阶学习资源工程化 / 框架 / 跨端 / 面试 / 架构 一起把技术学“明白”也用“到位”持续写作持续进阶。愿我们都能在代码和生活里走得更稳一点 文章目录引言一、为什么会出现“巨型页面”核心原因职责没有拆分二、正确拆分思路一句话原则正确结构三、第一步拆 Service页面写逻辑提取到 Service页面变成四、第二步拆 Store页面管理状态统一 Store页面只读五、第三步拆组件页面 UI 堆积拆组件页面使用六、第四步拆网络页面直接 fetchService 调用七、第五步引入模块化推荐结构八、最终页面应该长什么样理想页面九、判断标准出现这些正确状态十、为什么这很重要1、可维护性2、可扩展性3、团队协作4、避免“技术债”总结引言如果你写过一段时间鸿蒙游戏很可能已经遇到这个问题一个页面文件越来越大。最开始200 行后来变成800 行再后来2000 行 而且你会发现UI 写在一起逻辑写在一起网络写在一起状态也写在一起最后变成一个典型的“巨型页面文件God Component”在 HarmonyOS 的 ArkUI 体系下这个问题尤其常见。一、为什么会出现“巨型页面”核心原因职责没有拆分一个典型错误页面EntryComponentstruct GamePage{Statescore:number0Statelist:any[][]aboutToAppear(){this.loadData()}asyncloadData(){constresawaitfetch(/api/list)this.listawaitres.json()}movePlayer(){this.score1}build(){Column(){Text(Score:${this.score})Button(移动).onClick(()this.movePlayer())ForEach(this.list,item{Text(item.name)})}}}看起来没问题但其实混在一起了UI 状态 网络 逻辑一旦变复杂你会完全失控二、正确拆分思路一句话原则页面只负责 UI其它全部拆出去正确结构PageUI ↓ Service逻辑 ↓ Store状态 ↓ Network数据再加ComponentUI拆分 AgentAI三、第一步拆 Service页面写逻辑movePlayer(){this.score1}提取到 Service// services/GameService.etsimport{gameStore}from../store/GameStoreexportclassGameService{movePlayer(){gameStore.dispatch({type:ADD_SCORE,payload:1})}}exportconstgameServicenewGameService()页面变成Button(移动).onClick(()gameService.movePlayer())页面瞬间变干净。四、第二步拆 Store页面管理状态Statescore:number0统一 Store// store/GameStore.etsexportclassGameStore{state{score:0}dispatch(action){if(action.typeADD_SCORE){this.state.scoreaction.payload}}}exportconstgameStorenewGameStore()页面只读StatestategameStore.state页面不再“拥有状态”。五、第三步拆组件页面 UI 堆积Column(){Text(玩家)Image(avatar.png)Text(分数)}拆组件// components/PlayerInfo.etsComponentexportstruct PlayerInfo{Propscore:numberbuild(){Column(){Text(玩家)Text(分数${this.score})}}}页面使用PlayerInfo({score:this.state.score})页面只负责“拼装 UI”。六、第四步拆网络页面直接 fetchawaitfetch(/api/list)Service 调用awaitdataService.fetchList()页面完全不关心数据来源。七、第五步引入模块化当游戏变大推荐结构modules ├─ player │ ├─ PlayerService │ ├─ PlayerStore │ └─ PlayerComponent │ ├─ task ├─ battle原则按业务拆而不是按技术层拆八、最终页面应该长什么样理想页面EntryComponentstruct GamePage{StatestategameStore.statebuild(){Column(){PlayerInfo({score:this.state.score})Button(移动).onClick(()gameService.movePlayer())}}}页面只剩UI 事件绑定这才是正确形态。九、判断标准如果你的页面出现这些有 fetch有复杂逻辑有多层 if有状态计算说明已经“变胖了”。正确状态页面应该简单到可以一眼看懂十、为什么这很重要1、可维护性逻辑在 Service 状态在 Store修改不会影响 UI。2、可扩展性你可以轻松加AI多端网络3、团队协作UI开发 逻辑开发 AI开发可以分开做。4、避免“技术债”巨型页面的本质是技术债爆炸前兆总结避免“巨型页面文件”的核心方法1、逻辑进 Service 2、状态进 Store 3、UI 拆 Component 4、网络独立 5、按模块拆分在 HarmonyOS 的 ArkUI 架构中这不是“优化建议”而是必须遵守的架构规则

相关文章:

鸿蒙游戏如何避免“巨型页面文件”?

子玥酱 (掘金 / 知乎 / CSDN / 简书 同名) 大家好,我是 子玥酱,一名长期深耕在一线的前端程序媛 👩‍💻。曾就职于多家知名互联网大厂,目前在某国企负责前端软件研发相关工作,主要聚…...

保姆级教程:手把手教你用Visual Studio 2022编译Fluent与EDEM 2024耦合器(附资源获取)

从零到精通:Visual Studio 2022编译Fluent-EDEM耦合器全流程实战指南 当颗粒动力学遇上计算流体力学,Fluent与EDEM的耦合仿真为多相流研究打开了新世界。但对于刚接触这一领域的工程师和学生来说,编译耦合器往往是横亘在科研路上的第一道门槛…...

Seedance 2.0全面开放API服务

4月14日,字节跳动旗下的火山引擎正式向企业及个人开发者开放了Seedance 2.0系列API服务,这是其视频生成模型迈向全面商业化的关键一步。该模型定位为全球性能领先(SOTA)的多模态视频生成模型,此次开放不仅意味着将顶尖…...

B站会员购自动化抢票工具:终极指南与完整使用教程

B站会员购自动化抢票工具:终极指南与完整使用教程 【免费下载链接】biliTickerBuy b站会员购购票辅助工具 项目地址: https://gitcode.com/GitHub_Trending/bi/biliTickerBuy 🚀 你是否厌倦了在B站会员购抢票时总是慢人一步?biliTicke…...

QMC音频解码器:一键解锁加密音乐,实现跨平台播放自由

QMC音频解码器:一键解锁加密音乐,实现跨平台播放自由 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 还在为QQ音乐下载的加密音频无法在其他设备上播…...

避坑指南:Unity3D离线数字地球开发中的资源获取与优化技巧

Unity3D离线数字地球开发实战:资源获取与性能优化全攻略 在三维可视化领域,数字地球一直是令人着迷的技术挑战。当项目要求从在线环境转向离线部署时,开发者往往面临资源获取和性能优化的双重考验。我曾带领团队完成过三个离线数字地球项目&a…...

网卡高级设置优化指南:提升网络性能与稳定性

1. 网卡高级设置入门:为什么需要手动优化? 很多朋友可能遇到过这样的情况:明明家里装了千兆宽带,下载速度却总是不稳定;玩在线游戏时突然卡顿,明明网络信号满格;或者局域网传文件时速度像蜗牛爬…...

SeuratWrappers终极指南:3步解锁单细胞分析扩展工具集

SeuratWrappers终极指南:3步解锁单细胞分析扩展工具集 【免费下载链接】seurat-wrappers Community-provided extensions to Seurat 项目地址: https://gitcode.com/gh_mirrors/se/seurat-wrappers 你是否曾在使用Seurat进行单细胞数据分析时,渴望…...

别再手动改路径了!用Python脚本一键清洗你的Ultralytics YAML数据集配置文件

别再手动改路径了!用Python脚本一键清洗你的Ultralytics YAML数据集配置文件 在计算机视觉项目的日常开发中,数据集路径配置问题堪称"经典"的绊脚石。特别是当项目需要在Windows开发环境和Linux服务器之间频繁切换时,路径格式不一致…...

Python 类型提示:从基础到高级

Python 类型提示:从基础到高级 核心结论 类型提示:Python 3.5 引入的特性,用于静态类型检查基本类型:int, float, str, bool, list, dict 等内置类型高级类型:Union, Optional, List, Dict, Tuple, TypeVar, Protoco…...

终极Dell G15散热控制指南:从新手到专家的完整解决方案

终极Dell G15散热控制指南:从新手到专家的完整解决方案 【免费下载链接】tcc-g15 Thermal Control Center for Dell G15 - open source alternative to AWCC 项目地址: https://gitcode.com/gh_mirrors/tc/tcc-g15 还在为Dell G15游戏本的过热问题而烦恼吗&a…...

告别代码:QGIS 3.22可视化分割遥感影像,5步搞定YOLO训练数据

QGIS 3.22可视化分割遥感影像:零代码生成YOLO训练数据集实战指南 在计算机视觉项目中,高质量的数据预处理往往比模型架构更影响最终效果。传统Python脚本裁剪方式需要处理坐标系转换、像素对齐等复杂问题,而QGIS的可视化网格分割功能让这一切…...

GLM-4.1V-9B-Base创意无限:基于MATLAB算法仿真的AI艺术生成联动

GLM-4.1V-9B-Base创意无限:基于MATLAB算法仿真的AI艺术生成联动 1. 科学与艺术的奇妙碰撞 当严谨的数学计算遇上天马行空的AI想象力,会擦出怎样的火花?我们尝试将MATLAB生成的科学可视化图像输入GLM-4.1V-9B-Base模型,让AI为这些…...

若依(RuoYi)框架安全自查清单:开发者必须避开的5个高危配置与漏洞

若依(RuoYi)框架安全加固实战指南:5个关键防御策略与深度修复方案 若依框架作为国内广泛使用的开源快速开发平台,其安全性直接影响着成千上万企业系统的稳定运行。去年某金融机构因若依默认配置漏洞导致百万用户数据泄露的事件,再次提醒我们&…...

乙巳马年·皇城大门春联生成终端W数据持久化方案:C语言文件读写操作实例

乙巳马年皇城大门春联生成终端W数据持久化方案:C语言文件读写操作实例 最近在捣鼓一个挺有意思的小项目,一个运行在终端里的春联生成器。生成效果还不错,但每次运行完,那些有趣的春联文本就没了,下次想看看之前都生成…...

Ubuntu 22.04 下 Neo4j 5.3.0 安装与配置全攻略(含 Java 17 环境搭建)

Ubuntu 22.04 下 Neo4j 5.3.0 与 Java 17 全栈部署指南 当图数据库遇上现代开发需求,Neo4j 凭借其独特的属性图模型成为处理复杂关系数据的首选。本文将带您完成从 Java 环境搭建到 Neo4j 生产级部署的完整旅程,特别针对 Ubuntu 22.04 系统优化配置方案…...

解决Python卸载报错No Python 3.9 installation was detected的实用指南

1. 遇到"No Python 3.9 installation was detected"报错怎么办? 最近在帮同事清理开发环境时,遇到了一个典型问题:卸载Python 3.9时系统提示"No Python 3.9 installation was detected"。这个报错看似简单,但…...

AI教材写作新玩法:低查重秘诀,轻松搞定专业教材!

AI写作工具助力教材编写 教材的初稿终于完成,但接下来的修改和优化过程真是煎熬!在认真审阅全文时,我得仔细找出逻辑上的错误和知识点的偏差,这需要耗费我大量的时间;就算调整一个章节的结构,也会影响到后…...

所有的天气状态

这个问题其实没有一个**全球统一“固定数量”**的天气状态标准,不同气象机构(比如中国气象局、WMO、METAR航空天气)分类都不一样。 但在嵌入式/APP开发里,一般会用一个**“工程上够用 覆盖常见情况”**的分类,大概 2…...

从iCaRL到现实应用:拆解增量学习如何让AI模型持续进化

1. 增量学习:让AI像人类一样持续成长 第一次听说"增量学习"这个概念时,我正被一个推荐系统项目折磨得焦头烂额。每当新增商品类别时,模型就会像得了健忘症一样,把之前学到的用户偏好忘得一干二净。这让我意识到&#xf…...

必备!低查重AI教材生成宝藏工具,让AI写教材不再是难题!

引言:教材编写困境与AI的机遇 编写教材时,离不开充足的资料支持。传统的资料整合方法早已难以满足现代需求。曾几何时,课程标准、学术研究以及教学案例散落在知网、教研平台等各个渠道,筛选出有用的信息常常要花费几天的时间。即…...

DPO微调总让模型‘信心不足’?ICLR 2025这篇论文教你一个SFT阶段的小改动,轻松缓解‘挤压效应’

DPO微调中的‘挤压效应’:SFT阶段的小改动如何提升模型表现 大模型微调过程中,研究人员常常遇到一个令人头疼的现象——模型在DPO(直接偏好优化)阶段后,生成内容变得保守、单一,甚至丧失了原有的创造力。这…...

从Vulkan到SAPIEN再到RobotWin:一个云上机器人仿真环境的完整排错日志

云服务器A100环境下的Vulkan到RobotWin全链路排错实战 上周在云服务器上部署机器人仿真环境时,我遇到了一个令人抓狂的问题——从Vulkan到SAPIEN再到RobotWin的渲染链路中,不断出现segmentation fault和can not find render device错误。经过一周的反复排…...

Source Insight阅读Linux内核源码时结构体跳转失败的3种修复方法(附详细步骤)

Source Insight高效阅读Linux内核源码的深度实践指南 作为一名长期与Linux内核打交道的开发者,我深知代码导航工具的重要性。Source Insight作为老牌代码阅读利器,在大型项目如Linux内核中偶尔会出现结构体跳转失效的情况。本文将分享几种经过验证的解决…...

FRED应用:MTF的计算

描述FRED可以计算一个给定系统的MTF,本教程解释了如何来实现这个功能。建立系统这篇文章中我们所使用的系统是一个简单的透镜,将光聚集到附着在几何面的分析面上。透镜是一个简单的双凸BK7单透镜,参数为r160 mm, r2-300 mm, ct4 mm, x semi-a…...

LITESTAR 4D:面向未来的唯一BIM文件-IFC!

IFC:面向未来的唯一BIM文件!在全球范围内,BIM正逐渐成为建筑行业中一种新的广谱设计方法。BIM世界中最重要的方面之一是通过交换文件,也就是在制造商、设计师和市场之间传递信息:产品数据格式必须标准化到最高水平&…...

2025年知识竞赛软件评分排行榜权威解读

🏆 2025年知识竞赛软件评分排行榜权威解读多维评估 聚焦实用 选型指南📊 排行榜综述:多维评估,聚焦实用随着数字化教育的深入与企业培训形式的创新,知识竞赛软件已成为激发学习动力、检验培训成果的重要工具。2025年…...

终极指南:如何用VTube Studio API打造个性化虚拟主播体验

终极指南:如何用VTube Studio API打造个性化虚拟主播体验 【免费下载链接】VTubeStudio VTube Studio API Development Page 项目地址: https://gitcode.com/gh_mirrors/vt/VTubeStudio 想让你喜欢的虚拟主播根据直播弹幕做出不同表情吗?或者让角…...

告别虚拟机!在Win10/11上给Ubuntu 20.04分个家,手把手部署ego_planner无人机规划器

在Windows 10/11上安全部署Ubuntu 20.04双系统并运行ego_planner无人机规划器 对于无人机开发者和ROS爱好者来说,性能与稳定性往往是首要考虑因素。虚拟机虽然方便,但在资源占用和实时性方面存在明显短板。本文将带你一步步在Windows 10/11上安全安装Ub…...

从家庭WiFi到5G语音:手把手拆解VoWiFi(WiFi通话)的三种接入方式与安全机制

从家庭WiFi到5G语音:手把手拆解VoWiFi(WiFi通话)的三种接入方式与安全机制 走进一家咖啡厅,手机自动连上公共WiFi的瞬间,你是否想过——此刻拨出的电话可能正通过WiFi信号穿越半个城市,最终以运营商级的安…...