• [技术干货] 鸿蒙ArkTs项目配置 —— hvigor-config.json5
    在鸿蒙ArkTS项目中,hvigor/hvigor-config.json5 文件(或类似命名的配置文件,具体取决于项目的构建系统和插件)通常用于配置与ArkTS编译过程相关的选项和参数。这个文件可能不是鸿蒙官方SDK直接提供的一部分,而是由某个特定的构建工具或插件(如可能的Hvigor插件,尽管这不是鸿蒙官方直接提供的)使用的。hvigor/hvigor-config.json5 的默认配置如下{ "modelVersion": "5.0.0", "dependencies": { }, "execution": { // "analyze": "normal", /* Define the build analyze mode. Value: [ "normal" | "advanced" | false ]. Default: "normal" */ // "daemon": true, /* Enable daemon compilation. Value: [ true | false ]. Default: true */ // "incremental": true, /* Enable incremental compilation. Value: [ true | false ]. Default: true */ // "parallel": true, /* Enable parallel compilation. Value: [ true | false ]. Default: true */ // "typeCheck": false, /* Enable typeCheck. Value: [ true | false ]. Default: false */ }, "logging": { // "level": "info" /* Define the log level. Value: [ "debug" | "info" | "warn" | "error" ]. Default: "info" */ }, "debugging": { // "stacktrace": false /* Disable stacktrace compilation. Value: [ true | false ]. Default: false */ }, "nodeOptions": { // "maxOldSpaceSize": 8192 /* Enable nodeOptions maxOldSpaceSize compilation. Unit M. Used for the daemon process. Default: 8192*/ // "exposeGC": true /* Enable to trigger garbage collection explicitly. Default: true*/ } }.hvigor/hvigor-config.json5 的作用编译选项配置:允许开发者为ArkTS代码的编译过程指定各种选项,如分析模式、是否启用守护进程编译、增量编译、并行编译等。日志和调试:配置日志级别和调试选项,以帮助开发者在编译过程中获取更多信息或进行问题排查。Node.js选项:为构建过程中使用的Node.js进程配置内存限制和垃圾回收选项。配置方法在提供的示例中,hvigor-config.json5 文件包含了一些被注释掉的配置项。要配置这些选项,您只需取消注释相应的行,并根据需要修改其值。以下是一些可能的配置示例:启用高级分析模式:"execution": { "analyze": "advanced" }禁用增量编译:"execution": { "incremental": false }设置日志级别为调试:"logging": { "level": "debug" }调整Node.js的最大旧空间大小:"nodeOptions": { "maxOldSpaceSize": 4096 // 设置为4GB }注意事项文档和插件支持:由于.hvigor/hvigor-config.json5可能不是鸿蒙官方SDK直接提供的一部分,因此建议查阅与Hvigor插件或您正在使用的构建系统相关的文档,以获取有关如何配置和使用此文件的最新和最准确的信息。默认值:请注意,配置文件中列出了许多带有默认值的选项。如果您不确定某个选项的用途,可以保留其默认值,或查阅相关文档以获取更多信息。兼容性:随着鸿蒙OS和ArkTS框架的发展,构建系统和插件可能会发生变化。因此,请确保您的配置文件与当前使用的鸿蒙OS版本和构建系统兼容。安全性:如果配置文件包含敏感信息(尽管在这个特定的配置文件中不太可能),请确保妥善处理这些信息,以防止未经授权的访问。
  • [技术干货] 鸿蒙ArkTs项目配置 —— code-linter.json5
    在鸿蒙ArkTs项目中,code-linter.json5 文件(或类似命名的文件,具体取决于项目使用的代码检查工具)用于配置代码风格和质量检查(linting)的规则。这些规则帮助开发者维护代码的一致性和质量,通过自动化检查来避免常见的错误和不良实践。默认的配置如下:{ "files": [ "**/*.ets" ], "ignore": [ "**/src/ohosTest/**/*", "**/src/test/**/*", "**/src/mock/**/*", "**/node_modules/**/*", "**/oh_modules/**/*", "**/build/**/*", "**/.preview/**/*" ], "ruleSet": [ "plugin:@performance/recommended", "plugin:@typescript-eslint/recommended" ], "rules": { } }code-linter.json5 的作用指定检查的文件:通过 files 字段,可以指定哪些文件或文件类型应该被lint工具检查。忽略特定文件或目录:ignore 字段允许开发者指定哪些文件或目录应该被lint工具忽略,比如测试文件、构建产物、依赖库等。配置规则集:ruleSet 字段用于指定要使用的规则集,这些规则集定义了一系列lint规则。规则集可以是内置的,也可以是自定义的,或者是通过npm安装的插件提供的。自定义规则:rules 字段允许开发者覆盖或添加特定的lint规则,以满足项目的特定需求。配置方法在您提供的示例中,code-linter.json5 文件已经配置了一些基本的设置。以下是如何进一步配置或修改此文件的指导:指定检查的文件: 如果您想要检查除 .ets 文件之外的其他文件类型(比如 .ts 或 .js),您可以在 files 数组中添加相应的glob模式。忽略特定文件或目录: ignore 数组中的每个条目都是一个glob模式,用于指定应该被忽略的文件或目录。您可以根据需要添加或删除条目。配置规则集: ruleSet 字段列出了要使用的规则集。这些规则集应该与您的项目中安装的lint插件相对应。如果您想要使用不同的规则集,或者想要添加额外的规则集,请确保先通过npm安装相应的插件,并在 ruleSet 数组中指定它们。自定义规则: 在 rules 字段中,您可以覆盖 ruleSet 中定义的规则,或者添加新的规则。每个规则都是一个键值对,其中键是规则的名称(包括插件前缀,如果适用),值是规则的配置(通常是布尔值或对象)。注意事项插件兼容性:确保您安装的lint插件与您的项目兼容,并且支持您想要使用的规则集。规则文档:查阅您所使用的lint插件的文档,以了解每个规则的具体含义和配置选项。性能考虑:过多的lint规则可能会增加构建时间。在添加新规则时,请考虑它们对构建性能的影响。团队一致性:在团队项目中,确保所有成员都遵循相同的lint规则,以保持代码风格的一致性。最后,请注意,code-linter.json5 文件的名称和确切配置可能因您使用的lint工具而异。上述指导是基于您提供的文件内容和常见的lint配置实践。如果您使用的是特定的lint工具(如ESLint、TSLint等),请查阅该工具的官方文档以获取更详细的配置指导。
  • [技术干货] 鸿蒙ArkTs项目配置 —— local.properties
    在鸿蒙ArkTs项目中,local.properties 文件主要用于存储本地开发环境的配置信息,这些信息通常与项目的构建过程相关,但又不适合被纳入版本控制系统(如Git)中。这些配置信息可能包括SDK路径、NDK路径等,这些信息对于项目的构建和调试至关重要,但它们是特定于开发者的本地环境的,因此不应该被共享或提交到版本控制中。初始配置如下,默认并无任何配置# This file is automatically generated by DevEco Studio. # Do not modify this file -- YOUR CHANGES WILL BE ERASED! # # This file should *NOT* be checked into Version Control Systems, # as it contains information specific to your local configuration. # # For customization when using a Version Control System, please read the header note.local.properties 文件的作用存储本地配置:该文件用于存储项目构建过程中需要引用的本地资源路径,如SDK的安装位置、NDK的路径等。避免版本冲突:由于这些信息是特定于开发者的,将它们排除在版本控制之外可以避免不同开发者之间的配置冲突。自动生成:在某些情况下,如使用DevEco Studio等IDE时,local.properties 文件可能是自动生成的,并包含IDE根据当前开发环境配置的信息。配置方法对于local.properties文件,通常不需要手动编辑其内容,因为IDE(如DevEco Studio)会在项目构建或初始化时自动生成这个文件,并填充必要的配置信息。然而,如果由于某些原因需要手动配置这个文件,你应该注意以下几点:不要直接修改自动生成的文件:如果local.properties文件是由IDE自动生成的,并且包含了警告(如你提供的文件内容所示),那么最好遵循这些警告,不要直接修改这个文件。使用IDE的设置界面:大多数IDE都提供了图形化的设置界面,允许开发者配置SDK路径、NDK路径等构建相关的选项。通过IDE的设置界面进行配置,可以确保这些配置被正确地应用到项目中,并且不会被意外地覆盖或删除。了解你的开发环境:在手动配置local.properties文件之前,你需要了解你的开发环境,包括SDK和NDK的安装位置、版本等信息。这些信息对于正确配置文件至关重要。注意事项不要将local.properties文件添加到版本控制中:如前所述,这个文件包含特定于开发者的本地配置信息,因此不应该被纳入版本控制系统中。定期检查文件内容:尽管你通常不需要手动编辑local.properties文件,但定期检查其内容是一个好习惯。这可以帮助你确保IDE正确地配置了构建环境,并且你的项目可以在不同的开发环境中顺利构建。遵循IDE的文档和最佳实践:不同的IDE可能有不同的方式来处理local.properties文件和其他构建配置文件。因此,遵循你所使用的IDE的文档和最佳实践是非常重要的。
  • [技术干货] 鸿蒙ArkTs项目配置 —— oh-package.json5 与 oh-package-lock.json5 的区别
    在鸿蒙ArkTs项目中,oh-package.json5和oh-package-lock.json5两个文件扮演着不同的角色,主要区别在于它们的目的和内容。oh-package.json5目的:oh-package.json5文件主要用于描述项目的依赖包、全局配置等信息。它类似于Node.js项目中的package.json文件,但针对鸿蒙操作系统进行了定制。内容:包含项目的包名、版本、入口文件(类型声明文件)等信息。描述了项目所需的三方库(依赖项)及其版本,这对于项目的构建和部署至关重要。还可以包含全局配置信息,如依赖覆盖(overrides)、依赖关系重写(overrideDependencyMap)和参数化配置(parameterFile)等。使用场景:开发者在项目中添加、更新或删除依赖时,需要修改oh-package.json5文件。在构建项目时,构建工具会读取该文件以了解项目的依赖关系和其他配置信息。oh-package-lock.json5目的:oh-package-lock.json5文件是一个自动生成的文件,用于记录项目依赖关系的树形结构。它确保了在不同环境中项目的依赖能够保持一致,避免版本冲突。内容:包含了项目的所有依赖项及其版本号,形成了一个树形结构。每一层节点代表一个依赖项,子节点代表该依赖项的子依赖项。这种方式可以清晰地展示项目的依赖关系,有助于调试和优化项目。使用场景:oh-package-lock.json5文件在开发者首次运行依赖安装命令(如npm install或鸿蒙系统的对应命令)时自动生成。此后,每次运行依赖安装命令时,构建工具都会检查oh-package.json5和oh-package-lock.json5文件,以确保所有依赖项都按照锁文件中指定的版本进行安装。这有助于保持项目在不同环境中的一致性,避免因依赖项版本不同而导致的问题。总结oh-package.json5是项目的配置文件,由开发者手动编辑,用于描述项目的依赖关系和其他全局配置信息。oh-package-lock.json5是自动生成的文件,用于记录项目的依赖关系树形结构,确保在不同环境中项目的依赖能够保持一致。两者共同工作,确保项目的构建和部署过程顺利进行。
  • [技术干货] 鸿蒙ArkTs项目配置——module.json5
    module.json5 文件在鸿蒙ArkTs项目中扮演着至关重要的角色,它定义了应用程序(或称为模块)的基本信息和配置,包括其类型、描述、入口能力(Ability)、支持的设备类型、权限请求等。这个文件是鸿蒙系统应用开发和部署的基础配置之一。下面是对 module.json5 文件内容的逐行解释:{ "module": { "name": "entry", // 模块的名称,这里是"entry" "type": "entry", // 模块的类型,这里是"entry",表示这是一个入口模块,用户可以直接启动的模块 "description": "$string:module_desc", // 模块的描述,这里使用了资源字符串($string:)来引用,实际描述需要在资源文件中定义 "mainElement": "EntryAbility", // 指定模块的入口能力(Ability)名称,这里是"EntryAbility" "deviceTypes": [ // 支持的设备类型列表 "phone", // 支持手机 "tablet", // 支持平板 "2in1" // 支持二合一设备(如可插拔键盘的平板) ], "deliveryWithInstall": true, // 是否随安装包一起交付,这里为true,表示模块是随应用安装包一起安装的 "installationFree": false, // 是否支持免安装运行,这里为false,表示不支持免安装 "pages": "$profile:main_pages", // 页面的配置,这里使用了配置文件($profile:)来引用,实际配置需要在相应的配置文件中定义 "abilities": [ // 定义模块中的能力(Ability)列表 { // 第一个能力(Ability)的配置 "name": "EntryAbility", // 能力的名称 "srcEntry": "./ets/entryability/EntryAbility.ets", // 能力的入口文件路径 "description": "$string:EntryAbility_desc", // 能力的描述,使用了资源字符串 "icon": "$media:icon_app", // 能力的图标,使用了媒体资源($media:)来引用 "label": "$string:app_name", // 能力的标签,通常是应用名称,使用了资源字符串 "startWindowIcon": "$media:icon_app", // 启动窗口的图标,与能力的图标相同 "startWindowBackground": "$color:start_window_background", // 启动窗口的背景颜色,使用了颜色资源($color:)来引用 "exported": true, // 是否导出此能力,以便其他应用可以访问,这里为true "skills": [ // 定义能力可以响应的技能(如快捷方式、语音命令等) { "entities": ["entity.system.home"], // 技能关联的实体,这里是系统主页 "actions": ["action.system.home"] // 技能可以执行的动作,这里是打开系统主页 } ] } ], "extensionAbilities": [ // 定义模块中的扩展能力(ExtensionAbility)列表 { // 第一个扩展能力的配置 "name": "EntryBackupAbility", // 扩展能力的名称 "srcEntry": "./ets/entrybackupability/EntryBackupAbility.ets", // 扩展能力的入口文件路径 "type": "backup", // 扩展能力的类型,这里是"backup",表示备份能力 "exported": false, // 是否导出此扩展能力,这里为false "metadata": [ // 扩展能力的元数据列表 { "name": "ohos.extension.backup", // 元数据的名称,这里指定了备份能力的相关配置 "resource": "$profile:backup_config" // 元数据的资源路径,使用了配置文件($profile:)来引用 } ], } ], "requestPermissions": [ // 请求的权限列表 // 权限请求的配置,每个对象代表一个请求的权限 // ...(此处省略了具体的权限请求配置,但格式与上述类似) ] } }注意:在 requestPermissions 数组中,虽然给出了权限请求的示例格式,但具体的权限请求(如 ohos.permission.INTERNET)并未完全展示在提供的文件内容中。在实际应用中,您需要为每个请求的权限提供完整的配置,包括权限名称、请求原因以及使用场景等。此外,文件中的一些配置项(如 $string:、$media:、$color: 和 $profile:)使用了资源引用或配置文件引用的方式,这意味着实际的值将在构建过程中从相应的资源文件或配置文件中获取。这种方式有助于管理大型项目中的资源和配置,提高项目的可维护性和可扩展性。
  • [技术干货] 鸿蒙系统支持多设备的主要方式
    鸿蒙系统(HarmonyOS)作为一种面向分布式场景的操作系统,它通过一系列先进的技术和设计理念来支持多设备互联与协同工作。以下是鸿蒙系统支持多设备的主要方式:1. 分布式软总线技术连接设备:鸿蒙系统采用分布式软总线技术,将不同的设备连接在一起,实现设备之间的无缝通信和数据共享。这种技术类似于一个虚拟的“高速公路”,让数据可以在不同设备间自由流动。数据共享:通过分布式软总线,用户可以轻松地在不同设备间共享文件、图片、视频等数据,实现跨设备的无缝体验。2. 分布式数据管理数据存储:鸿蒙系统采用分布式数据管理技术,将数据存储在不同的设备上,并通过分布式事务处理机制保证数据的一致性和安全性。数据同步:系统能够实时同步数据变化,确保用户在任何设备上都能获取到最新的数据状态。3. 分布式能力调度资源调度:鸿蒙系统通过分布式能力调度技术,将不同设备的计算能力和资源进行统一调度和管理。这意味着系统可以根据设备的实际情况和用户需求,智能地分配资源,提高系统的整体效率和性能。任务协同:用户可以在多个设备上同时使用同一个应用程序,比如在手机上开始的任务可以无缝地切换到平板电脑上继续进行。4. 设备虚拟化技术统一资源池:鸿蒙系统采用设备虚拟化技术,将不同的设备虚拟化为一个统一的资源池。这使得系统可以更加灵活地管理和利用设备资源,提高设备的利用率和灵活性。5. 统一的应用框架和开发工具应用开发:鸿蒙系统提供了一套完整的应用框架和开发工具,支持开发者在不同的设备上开发和部署应用程序。这些工具包括IDE(集成开发环境)、API(应用程序接口)等,为开发者提供了便捷的开发环境和丰富的开发资源。应用兼容:通过统一的应用框架和开发工具,鸿蒙系统可以确保应用程序在不同设备上的兼容性和可移植性。6. 设备发现和接入机制设备发现:鸿蒙系统提供了统一的设备发现和接入机制,使得不同设备之间能够方便地互相发现和建立连接。用户可以通过一台设备找到其他设备并进行连接,实现多设备之间的无缝体验。7. 跨屏协同协同操作:鸿蒙系统支持跨屏协同功能,可以实现多个设备之间的协同操作。比如,在手机上浏览网页时,用户可以将网页无缝推送到电视屏幕上观看;在平板电脑上编辑文档时,可以实时同步到电脑上进行进一步编辑。综上所述,鸿蒙系统通过分布式软总线、分布式数据管理、分布式能力调度、设备虚拟化、统一的应用框架和开发工具、设备发现和接入机制以及跨屏协同等多种方式,实现了对多设备的全面支持。这些技术和设计理念的应用,使得鸿蒙系统能够为用户提供更加便捷、高效、智能的跨设备体验。
  • [技术干货] 鸿蒙相对安卓的优势
    鸿蒙系统(HarmonyOS)与安卓系统(Android)相比,具有多方面的优势。以下是对鸿蒙系统优势的具体分析:1. 分布式架构与多设备协同分布式架构:鸿蒙系统采用分布式架构,能够实现设备、云和边缘计算资源的统一管理和调度。这种架构使得不同设备之间可以直接通信和协同操作,大大提高了设备之间的数据交互效率和用户体验。相比之下,安卓系统虽然也支持多设备互联,但在分布式架构和协同能力上相对较弱。多设备统一体验:鸿蒙系统通过鸿蒙分布式软总线技术,实现了多种设备之间的无缝协同,包括手机、平板、电视、智能手表等终端设备。用户可以在不同设备间轻松切换和共享数据,享受一致的操作体验。而安卓系统则没有如此全面的多设备统一体验支持。2. 性能与流畅性卓越性能:鸿蒙系统具有高性能体验,其启动速度、应用响应速度等方面都比其他操作系统更快。这得益于鸿蒙系统的优化设计和底层技术的支持。相比之下,安卓系统在流畅性和卡顿问题上一直备受批评,尤其是在中低端设备上表现更为明显。3. 安全性与隐私保护安全保障:鸿蒙系统将安全作为设计和开发的重要目标,采用微内核架构,实现了严格的进程隔离和权限分离,减少了一些安全问题。同时,鸿蒙系统还提供了设备之间的安全通信机制和加密技术,保障用户数据的隐私和安全。而安卓系统由于开放性较高,容易受到恶意软件和病毒程序的攻击。4. 应用开发与生态系统统一开发框架:鸿蒙系统采用HarmonyOS框架,支持多种开发语言(如C/C++、Java、JavaScript等)和统一的编程接口及开发工具。这使得开发者可以以更快的速度和更高的效率开发多种设备支持的应用程序。相比之下,安卓系统的应用开发则需要根据不同设备的组合进行适配,增加了开发难度和成本。生态系统建设:虽然目前鸿蒙系统的应用生态系统相对安卓系统还不够成熟和丰富,但鸿蒙系统正在积极推进开发者生态建设,并吸引了越来越多的开发者和合作伙伴参与进来。随着鸿蒙系统的不断发展和完善,其生态系统有望逐渐壮大并为用户提供更多样化的应用选择。5. 人工智能与智能化服务人工智能集成:鸿蒙系统加入了人工智能技术,可以实现更加智能化的功能和服务。例如,用户可以通过语音或手势控制设备,使得设备的操作更加便捷和智能。这种智能化的服务体验是安卓系统所不具备的。综上所述,鸿蒙系统在分布式架构与多设备协同、性能与流畅性、安全性与隐私保护、应用开发与生态系统以及人工智能与智能化服务等方面具有显著的优势。这些优势使得鸿蒙系统能够更好地满足用户对于智能设备互联、高效操作、安全隐私保护以及智能化服务等方面的需求。
  • [公告] 【获奖公示】DTSE Tech Talk丨NO.66:鸿蒙上云,加速开发者成长
    中奖结果公示感谢各位小伙伴参与本次活动,欢迎关注华为云DTSE Tech Talk 技术直播更多活动~本次活动获奖名单如下(部分视频号抽奖用户无账号名):账号名 奖项名称 奖品名称 harmonypass优质提问华为云开发者定制双肩包(简约款)nukinsan优质提问华为云开发者定制双肩包(简约款) 口令抽奖华为云云宝手办盲盒 口令抽奖华为云云宝手办盲盒 口令抽奖华为云云宝手办盲盒 视频号抽奖华为云开发者定制折叠雨伞 视频号抽奖华为云开发者定制折叠雨伞 视频号抽奖华为云开发者定制折叠雨伞
  • [分享交流] 【华为开发者布道师技术沙龙】从学生社区开发者到华为开发者布道师有何秘籍?
    活动信息【活动主题】:逐梦之旅:学生开发者到华为开发者布道师的蜕变【报名链接】:cid:link_0【直播时间】:2024/09/29 19:00-20:00【直播嘉宾】:华为开发者布道师 郑州轻工业大学梅科尓工作室的核心成员杨阳【直播链接】:【待09/29号直播前提供】【直播简介】:以自身经历出发,详细介绍从华为开发者学生社区成员到成为华为开发者布道师的历程。通过具体项目案例,将分享如何利用华为的技术资源和平台工具实现技术上的突破与创新,并探讨如何在快速变化的技术环境中持续学习和开发者成长的重要性。【直播福利】:福利一:互动有礼1.礼品列表:定制开发者布道师Polo杉,抽华为定制充电宝2.官网直播间参与互动,发口令抽华为精美礼品。福利二:有奖提问1.礼品列表:定制开发者布道师保温杯福利三:连续打卡1.后续会上线一系列的开发者布道师线上直播活动,连续参加活动并签到的开发者,会获得连续签到激励,奖品多多,敬请期待!    
  • [热门活动] “连接未来,智慧无限”HCDG城市行深圳站——人工智能&鸿蒙生态创新论坛圆满成功!
    8月23日,“连接未来,智慧无限”HCDG城市行深圳站——人工智能&鸿蒙生态创新论坛活动在深圳市南山区华侨城创意文化园成功举办。活动以"人工智能&鸿蒙生态创新"为主题,吸引了众多行业专家和业务领袖齐聚一堂,共同探讨云原生、Devops、鸿蒙技术生态构建、AI原生应用引擎等前沿话题。论坛伊始,华为深圳云生态云原生DTSE技术专家朱红磊先生带来的主题为“云原生和Devops助力企业数字化转型”的精彩分享,深入浅出地阐述了云原生技术如何通过提供可扩展的、灵活的、高效的解决方案来支持企业快速实现数字化转型。朱专家强调,Devops作为一种自动化和持续交付的方法,与云原生技术相结合,能够帮助企业更快地响应市场变化,提高业务的灵活性和竞争力。随后,华为深圳云生态鸿蒙DTSE技术专家刘文明先生就“鸿蒙技术的生态构建与发展趋势”进行了深度解读。刘先生指出,鸿蒙操作系统作为一个全场景智能生态系统,正通过其独特的微内核设计和分布式架构,不断强化与各行各业的融合,推动智能生态的广泛构建。他预测,随着鸿蒙生态的不断壮大,未来将有更多设备和服务采用鸿蒙系统,实现跨平台的无缝协同。论坛第三个环节由华为云AI原生应用引擎产品总监李明先生主讲,主题为“华为云AI原生应用引擎0代码智能构建专属个性化应用”。李先生介绍了华为云AI原生应用引擎如何利用0代码平台,帮助开发者和企业快速构建和部署AI应用,从而降低技术门槛,加速AI应用的普及和应用。他强调,这一平台为企业提供了个性化、定制化的AI解决方案,使得非专业人士也能轻松享受到人工智能技术带来的便利。最后,活动进入互动交流与实验体验环节。与会嘉宾和参与者通过深入交流,不仅加深了对云原生、Devops、鸿蒙技术和AI原生应用引擎的理解,还就如何将这些技术应用于实际业务中进行了充分探讨。现场的实验体验环节更是让参与者亲身体验了华为技术的强大性能和灵活性。华为云将继续携手各城市HCDG核心组成员,与广大企业及开发者,共建产业新生态,为企业及开发者提供“新技术、新体验、新机会”全方位支撑,赋能更多的企业数字化转型。HCDG(Huawei Cloud Developer Group 华为云开发者社区组织),是基于城市圈和技术圈,由开发者核心组自发开展的开放、创新、多元的社区技术交流组织,致力于帮助开发者学习提升、互动交流、挖掘合作,推动技术应用与本地产业结合、数智化转型和开发者文化发展。
  • [技术干货] 鸿蒙数据的3种存储方式(Preferences、KV-Store、RelationalStore)
    在选择ArkTs中适合的数据存储方式时,主要考虑以下几个方面:数据类型、数据量、数据同步需求、性能需求以及数据的安全性和可维护性。下面分别说明何时应使用这三种不同的存储方式:1. 用户首选项(Preferences)适用场景:轻量级配置数据的持久化:当应用需要保存用户的一些偏好设置或者轻量级的配置信息时,比如应用的主题、语言选择、用户是否同意某些条款等。不支持分布式同步:如果应用不需要跨设备同步这些配置信息,使用Preferences是非常合适的。需要订阅数据变化:当应用需要实时响应用户偏好或配置的变化时,Preferences提供了数据变化通知的能力,便于实现UI或功能的即时更新。2. 键值型数据管理(KV-Store)适用场景:键值型数据的存储与检索:当应用需要频繁读写简单的键值对数据时,如用户登录状态、临时缓存信息等。分布式同步需求:如果应用需要在不同设备或用户之间同步数据,如用户的登录状态、进度信息等,KV-Store通过DatamgrService提供的分布式同步能力非常有用。高性能与可扩展性:键值型数据库通常具有高性能和可扩展性,适合处理大量的小数据项。数据加密与备份:如果应用对数据安全性有较高要求,或者需要定期备份数据,KV-Store提供的加密和手动备份功能非常有用。3. 关系型数据管理(RelationalStore)适用场景:复杂关系数据的存储:当应用需要存储的数据具有复杂的关系,如用户信息、订单信息、商品信息等,并且这些数据之间存在关联关系时,关系型数据库是更好的选择。需要强事务控制:关系型数据库支持ACID(原子性、一致性、隔离性、持久性)事务,这对于需要强数据一致性和可靠性的应用非常关键。分布式同步需求:类似于KV-Store,RelationalStore也支持通过DatamgrService进行跨设备的数据同步,适合需要同步复杂关系数据的场景。查询性能:关系型数据库提供了丰富的查询能力,支持复杂的SQL查询,这对于需要进行复杂数据分析和报表生成的应用非常有用。总结选择哪种数据存储方式,需要根据应用的具体需求和数据特性来决定。对于轻量级的配置和偏好设置,Preferences是理想的选择;对于简单的键值型数据和需要分布式同步的场景,KV-Store是更好的选择;而对于需要存储复杂关系数据、强事务控制、复杂查询或分布式同步的应用,RelationalStore是更适合的选择。
  • [行业前沿] 【话题交流】鸿蒙和安卓的区别
    鸿蒙NEXT在10月就要上线了,大家来聊聊鸿蒙与安卓的区别
  • [技术干货] 鸿蒙开发常用注解
    在鸿蒙(HarmonyOS)开发中,注解(Annotation)是一种用于描述代码中的信息的元数据,它们不会改变程序的执行流程,但可以用于在编译时或运行时对代码进行解析和操作。鸿蒙开发中常见的注解及其用途包括但不限于以下几点:@Entry:标记一个类作为Ability的入口类,通常用于定义页面的启动。@Component:标记一个类为组件类,可以是页面(Page)、服务(Service)等。@State:在响应式UI框架中,标记类的成员变量为状态变量。当状态变量变化时,界面会重新渲染。@Prop:在自定义组件中,用于接收父组件传递的属性值。@Link:用于组件之间的数据传递和绑定,通常与@Prop配合使用。@Observed:在响应式UI框架中,标记一个类为可观察对象。当类的成员变量变化时,可以通知订阅了该对象的组件。@ObjectLink:标记类的成员变量为跨设备对象链接,通常用于多设备协同场景。@Autowired:自动装配依赖,用于在类中自动注入需要的服务或资源。@RequiresPermission:标记一个方法或类需要特定的权限才能执行。@Syscap:标记系统能力,用于声明能力请求的权限信息,比如访问网络、存储等。@AbilityContext:标记方法的参数,用于从Ability中注入AbilityContext对象。@Subscribe:标记一个方法为事件订阅方法,用于监听和响应特定事件。@Command:标记一个方法为命令方法,通常用于ServiceAbility中,用于响应来自其他Ability的命令。@DataStorage:标记类为数据存储类,用于声明与数据存储相关的配置。@StorageProp:标记类的成员变量为需要自动存储和恢复的属性。@LayoutConfig:用于页面组件,配置页面的布局配置信息。@ContentUri:标记一个字段为内容URI,通常用于媒体文件或文件资源的引用。@Param:标记方法的参数,用于指定参数的类型、名称等信息,常用于路由跳转或事件传递中。@Builder:用于构建模式的注解,可以自动生成构建类的代码。
  • [技术干货] 鸿蒙webview加载的3个性能指标(FCP、FMP、LCP)
    在鸿蒙(HarmonyOS)的WebView组件中,关于网页加载过程的性能指标FCP(First Contentful Paint)、FMP(First Meaningful Paint)和LCP(Largest Contentful Paint)的调用时机和它们之间的区别,可以归纳如下:调用时机FCP(First Contentful Paint)首次内容绘制:调用时机:当页面开始绘制第一个内容元素(如文本、图像、非空白Canvas或SVG)时触发。这是用户首次在视觉上感知到页面加载进度的时刻。目的:衡量页面加载的早期性能,标识页面开始渲染的时间点。FMP(First Meaningful Paint)首次有效绘制:调用时机:比FCP更晚,当页面主要内容开始出现在屏幕上时触发。这通常标志着页面达到了一个用户认为“有用”或“可交互”的状态。目的:衡量页面加载到用户认为可交互状态所需的时间,虽然这个指标的精确性可能因页面内容和用户感知而异。LCP(Largest Contentful Paint)最大内容绘制:调用时机:在可视区域内,页面上的最大内容元素(如图片、视频或文本块)开始出现在屏幕上时触发。这通常反映了页面加载的完成度和用户视觉上的主要关注点。目的:评估页面加载的最终性能和用户体验,特别是针对包含大量视觉元素的页面。它们之间的区别性能指标调用时机主要关注点FCP页面开始绘制第一个内容元素时衡量页面加载的早期性能,用户首次感知到加载进度的时刻FMP页面主要内容开始出现在屏幕上时衡量页面加载到用户认为可交互状态所需的时间,尽管精确性可能因页面和用户而异LCP可视区域内最大内容元素开始出现在屏幕上时评估页面加载的最终性能和用户体验,特别是针对视觉元素丰富的页面在鸿蒙WebView组件中,这些性能指标通常通过特定的事件或回调函数来通知开发者,如onFirstContentfulPaint、onFirstMeaningfulPaint和onLargestContentfulPaint。这些回调函数的调用时机与上述描述的调用时机相对应,允许开发者在WebView加载网页的过程中,监控并优化页面的加载性能和用户体验。请注意,由于鸿蒙系统的不断发展和更新,具体的API接口和性能指标的细节可能会有所变化。因此,建议开发者参考最新的鸿蒙系统文档和API指南以获取最准确的信息。
  • [技术干货] 鸿蒙中的FA模型和Stage模型
    鸿蒙系统中的FA模型和Stage模型是两种不同的应用开发模型,它们在设计思想、组件类型、资源共享和内存占用、系统管理和控制能力,以及模型演进和主推程度等方面存在显著的差异。FA模型FA模型是“Feature Ability”(功能能力)的缩写,是HarmonyOS早期版本开始支持的模型。该模型基于微内核架构,通过IPC(进程间通信)和分布式软总线完成轻量化、松耦合的模块间通信和服务调用。其主要特点包括:分布式调度:支持分布式调度,具有实时计算和交互控制的特性。独立引擎实例:每个应用组件独享一个ArkTS引擎实例,没有实现组件间的资源共享和内存优化。系统管理能力:在系统管理和控制能力方面,FA模型没有像Stage模型那样强调对后台进程的有序治理和严格管理。Stage模型Stage模型是HarmonyOS 3.1及后续版本主推且会长期演进的模型,它提供了一种更好的开发方式,更适用于多设备、分布式场景。Stage模型的主要特点包括:组件共享:多个应用组件共享同一个ArkTS引擎实例,使得应用组件之间可以方便地共享对象和状态,同时减少复杂应用运行对内存的占用。多窗口管理:Stage模型将应用的界面划分为多个独立的Stage,每个Stage都有自己的窗口和界面布局,可以单独显示、隐藏和关闭。不同的Stage之间可以进行切换和互动,提供了更加丰富的用户交互方式。组件类型:提供UIAbility和ExtensionAbility两种类型的组件。UIAbility组件用于与用户交互,而ExtensionAbility组件则提供场景化的服务扩展机制,但不提供自定义服务的能力。生命周期管理:UIAbility组件的生命周期包含创建、销毁、前台、后台状态,与界面强相关的获焦、失焦状态都放在窗口管理对象中,实现与窗口之间的弱耦合。系统管理能力:对后台应用进程进行了有序治理,应用程序不能随意留驻在后台,同时应用后台行为受到严格管理,以防止恶意应用行为。总结FA模型和Stage模型在鸿蒙系统中各有其应用场景和优势。FA模型更适合于需要高度独立性和轻量级通信的场景,而Stage模型则更适用于多设备、分布式场景下的复杂应用开发。随着HarmonyOS的不断演进,Stage模型将成为未来应用开发的主流方向。开发者在选择使用哪种模型时,应根据具体的应用需求、系统环境和技术要求进行综合考虑。
总条数:126 到第
上滑加载中