第一讲_HarmonyOS应用开发环境准备

HarmonyOS应用开发环境准备

  • 1. 知识储备
  • 2. 环境搭建
    • 2.1 安装node.js
    • 2.2 配置node.js
    • 2.3 安装命令行工具
    • 2.4 安装DevEco Studio
    • 2.5 配置DevEco Studio

1. 知识储备

HarmonyOS提供了一套UI开发框架,即方舟开发框架(ArkUI框架)。方舟开发框架可为开发者提供应用UI开发所必需的能力。

ArkTSHarmonyOS优选的主力应用开发语言。ArkTS围绕应用开发在TypeScript生态基础上做了进一步扩展,继承了TypeScript的所有特性,是TypeScript的超集。

TypeScript是通过在JavaScript的基础上添加静态类型定义构建而成。

因此,在进行HarmonyOS应用开发之前,需要掌握以下三种语言:

  • JavaScript
  • TypeScript
  • ArkTS

不具备以上基础的开发同学,也不用担心。可以持续关注下我的博客,接下来我会写一系列关于HarmonyOS应用开发的博文,从ArkTS语言基础开始。共同学习、共同探讨、共同进步,熟练的掌握HarmonyOS应用开发的技能。

2. 环境搭建

2.1 安装node.js

node.js 安装包下载地址:node.js官网
在这里插入图片描述
ps:下载LTS版本即可,当前最新版本可能不太稳定。

2.2 配置node.js

  • 安装完node.js,可以查看node.jsnpm的版本。
# 查询node.js版本号
node -v# 查询npm的版本号
npm -v
  • 配置npm仓库的地址信息。
npm config set registry https://repo.huaweicloud.com/repository/npm/

2.3 安装命令行工具

该命令行工具集合了HarmonyOS应用开发所用到的系列工具,包括SDK管理sdkmgr、代码检查codelinter、三方库的包管理ohpm
在这里插入图片描述

  1. 命令行工具安装包下载,下载地址:命令行工具下载
  2. 解压文件,进入“ohpm/bin”目录,执行如下指令初始化ohpm。
    • Windows 系统执行 init.bat
    • macOS 系统执行./init.sh
  3. ohpm配置到环境变量中。
    • Windows 环境变量配置:电脑 > 属性 > 高级系统设置 > 高级 > 环境变量中,将ohpm命令行工具的bin目录路径添加到PATH变量中。
    • macOS 环境变量配置:
      export OHPM_HOME=ohpm的安装路径
      export PATH=${OHPM_HOME}/bin:${PATH}
  4. 安装完成之后,执行如下命令:ohpm -v

2.4 安装DevEco Studio

HUAWEI DevEco Studio 是 HarmonyOS 应用开发的官方指定工具。

HUAWEI DevEco Studio 安装包下载地址:DevEco Studio 下载

在这里插入图片描述

2.5 配置DevEco Studio

  1. 运行已安装的DevEco Studio,选择Do not import settings,单击OK。
  2. 安装Node.js与ohpm。可以指定本地已安装的Node.js或ohpm(选择Local)。

在这里插入图片描述3. 在SDK Setup界面,单击按钮,设置HarmonyOS SDK存储路径,单击Next进入下一步。

在这里插入图片描述

  1. 在弹出的SDK下载信息页面,单击Next,并在弹出的License Agreement窗口,阅读License协议,需同意License协议后,单击Next。

在这里插入图片描述

  1. 确认设置项的信息,点击Next开始安装。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/631065.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springboot minio 工具类,一站式解决

注意 minio 新版本有9000和9090两个端口&#xff0c;web访问是9000&#xff0c;但走api上传和访问都是9090端口 引入pom <dependency><groupId>io.minio</groupId><artifactId>minio</artifactId><version>8.2.0</version></d…

给WordPress网站增加一个带时间的led广告牌

WordPress 后台》外观》小工具》自定义html》添加到合适位置 其他系统可自行添加合适位置 <style type"text/css">.studytextgzbox {background: #F9F9F9; border: 1px solid #999999;margin: 1px;text-align:center; float: left;line-height: 28px;hei…

Qt中ComboBox的简单使用

1.相关说明 combobox中item的文字、data、图片设置 2.界面绘制 3.相关主要代码 #include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete …

回归预测 | Matlab实现MSADBO-CNN-LSTM基于改进蜣螂算法优化卷积神经网络-长短期记忆神经网络多特征回归预测

回归预测 | Matlab实现MSADBO-CNN-LSTM基于改进蜣螂算法优化卷积神经网络-长短期记忆神经网络多特征回归预测 目录 回归预测 | Matlab实现MSADBO-CNN-LSTM基于改进蜣螂算法优化卷积神经网络-长短期记忆神经网络多特征回归预测预测效果基本描述程序设计参考资料 预测效果 基本描…

从0开始python学习-48.pytest框架之断言

目录 1. 响应进行断言 1.1 在yaml用例中写入断言内容 1.2 封装断言方法 1.3 在执行流程中加入断言判断内容 2. 数据库数据断言 2.1 在yaml用例中写入断言内容 2.2 连接数据库并封装执行sql的方法 2.3 封装后校验方法是否可执行 2.4 使用之前封装的断言方法&#xff0c…

关于VScode的这个ssh的配置的经验

1.首先&#xff0c;我是因为重装了ubantu系统&#xff0c;不得不重新配置ssh 2.第一步&#xff0c;在本机的终端安装ssh插件&#xff1a; &#xff08;1&#xff09; &#xff08;2&#xff09;restart开启这个ssh端口 3.然后&#xff0c;就在vscode里面&#xff0c;安装哪个…

使用CSS计算高度铺满屏幕

前言 今天写项目时出现高度设置百分百却不占满屏幕&#xff0c;第一反应看自己设置的是块级元素还是行级元素。看了几篇博客&#xff0c;发现并不能解决问题。脱离文档流的做法都没考虑&#xff0c;前期模板搭建脱离文档流&#xff0c;后面开发会出现很多问题。 以上图片是我…

FindMy技术与相机结合

FindMy是苹果公司提供的设备追踪服务&#xff0c;用来帮助用户定位丢失的设备。自苹果公司开放Findmy网络之后&#xff0c;FindMy技术便与各种生活设备相结合&#xff0c;比如与相机的结合。 想象一下&#xff0c;你正在外出办事或者旅行时&#xff0c;突然意识到相机丢了&…

SSR服务端渲染解决了什么问题?有做过SSR吗?

面试官&#xff1a;SSR解决了什么问题&#xff1f;有做过SSR吗&#xff1f;你是怎么做的&#xff1f; 一、是什么 Server-Side Rendering 我们称其为SSR&#xff0c;意为服务端渲染 指由服务侧完成页面的 HTML 结构拼接的页面处理技术&#xff0c;发送到浏览器&#xff0c;然…

Unity关于新手引导中实现遮罩镂空效果

在新手引导每一步中实现可以遮掉其他部分而显示当前需要点击的部分&#xff0c;只需要在每一步引导的时候设置对应的镂空区域的RectTransform.效果如下图&#xff1a; 代码&#xff1a; public class SelfMaskSet : MaskableGraphic, ICanvasRaycastFilter {[SerializeField]p…

React的合成事件

合成事件&#xff1a;通过事件委托&#xff0c;利用事件传播机制&#xff0c;当事件传播到document时&#xff0c;再进行分发到对应的组件&#xff0c;从而触发对应所绑定的事件&#xff0c;然后事件开始在组件树DOM中走捕获冒泡流程。 原生事件 —— > React事件 —— >…

嵌入式培训机构四个月实训课程笔记(完整版)-C++和QT编程第四天-C++动态联编和虚函数练习(物联技术666)

链接:https://pan.baidu.com/s/1KayCjn6Vem9YFucS8lpCFg?pwd=1688 提取码:1688 设计一个动物类:动物有一个name成员,另外有三个函数sleep(), eat(), play(); 从动物这个类派生出狗类和猫类,在对应的三个函数中实现输出如下信息的功能: dog(or cat) (name) is sleepping…

互联网技术发展:技术行业的深度思考

随着互联网技术的日新月异&#xff0c;我们身处一个信息爆炸的时代。技术行业作为这场变革的引擎&#xff0c;不断推动着社会的进步。然而&#xff0c;当我们沉浸在这场技术盛宴中时&#xff0c;是否曾停下脚步&#xff0c;思考其背后的深远影响&#xff1f;本文将从一个独特的…

macOS 13(本机)golang程序交叉编译成 ARM架构

## 背景 golang程序&#xff08;JuiceFS&#xff09;需要支持ARM64架构&#xff0c;重新编译&#xff1b; 本地环境&#xff1a;macOS&#xff1a;13 ## 操作 安装交叉编译工具&#xff1a; brew install FiloSottile/musl-cross/musl-cross --with-aarch64 可以在 /usr/l…

C++ 一元运算符重载

一元运算符只对一个操作数进行操作&#xff0c;下面是一元运算符的实例&#xff1a; 递增运算符&#xff08; &#xff09;和递减运算符&#xff08; – &#xff09;一元减运算符&#xff0c;即负号&#xff08; - &#xff09;逻辑非运算符&#xff08; ! &#xff09; 一…

【数据结构】二叉树-堆(top-k问题,堆排序,时间复杂度)

&#x1f308;个人主页&#xff1a;秦jh__https://blog.csdn.net/qinjh_?spm1010.2135.3001.5343&#x1f525; 系列专栏&#xff1a;《数据结构》https://blog.csdn.net/qinjh_/category_12536791.html?spm1001.2014.3001.5482 ​​ 目录 堆排序 第一种 ​编辑 第二种 …

Python兴趣篇_模拟编译中的字典运用

在Python基础篇_字典基本操作中说到&#xff0c;字典可以用于存储编译时需要的信息或参数。 本文就来简单讨论一下模拟编译过程中如何利用字典数据类型&#xff1b; 模仿编译过程中&#xff0c;Python 字典可以用于存储和处理与编译相关的各种信息。以下是 Python 字典在模拟编…

【征服redis8】Redis的AOF持久化

Redis 支持多种持久化方式来保证数据的可靠性和持久性。前面我们介绍了RDB方式。我们我们介绍第二种方式——AOF&#xff08;Append Only File&#xff09;机制是一种常用的持久化方式&#xff0c;它记录了所有对 Redis 数据库进行修改的命令&#xff0c;在 Redis 重启时可以使…

【办公自动化】利用Python代码暴力破解RAR压缩包的密码

title: 利用Python代码暴力破解RAR压缩包的密码 tags: bigleft excerpt: 利用Python代码暴力破解RAR压缩包的密码 利用Python代码暴力破解RAR压缩包的密码 引言 有时从网盘或p2p下载了几个G的资源&#xff0c;下载了几天&#xff0c;终于下载完成&#xff0c;结果发现来需要密…

条款43:学习处理模板化基类内的名称

1.前言 假设我们需要编写一个程序&#xff0c;它能够传送信息到若干不同的公司去。信息要不编译称密码&#xff0c;要不就是未加工的文字。如果编译器间我们有足够的信息来决定哪一个信息传至哪一家公司&#xff0c;就可以采用基于template的解法&#xff1a; class Company{…