HarmonyOS应用开发-基本控件
头像 Tiechui.Wang 2020-09-14 11:54:00    发布
2721 浏览 15 点赞 10 收藏

1、介绍

本篇CodeLab将实现的内容
HarmonyOS是面向全场景多终端的分布式操作系统,使得应用程序的开发打破了智能终端互通的性能和数据壁垒,业务逻辑原子化开发,适配多端。通过一个简单应用开发,体验HarmonyOS的基本控件使用。

您将建立什么
在这个CodeLab中,你将创建Demo Project,并将Demo编译成HAP,部署到智慧屏上,以实现HarmonyOS基本控件使用。

您将会学到什么
如何创建一个HarmonyOS Demo Project
如何构建一个HAP并且将其部署到智慧屏上
通过此示例应用体验在HarmonyOS上如何使用基本控件,包括文本输入框,日期选择控件,单选按钮,下拉菜单和按钮

2. 您需要什么

硬件要求
操作系统:Windows10 64位
内存:8G及以上
硬盘:100G及以上
分辨率:1280*800及以上

软件要求
安装DevEco Studio和Node.js,详情请参考下载和安装软件
设置DevEco Studio开发环境,DevEco Studio开发环境需要依赖于网络环境,需要连接上网络才能确保工具的正常使用,可以根据如下两种情况来配置开发环境
1. 如果可以直接访问Internet,只需进行下载HarmonyOS SDK操作
2. 如果网络不能直接访问Internet,需要通过代理服务器才可以访问,请参考配置开发环境

需要的知识点
JavaScript基础开发能力。

3. 能力接入准备
实现HarmonyOS应用开发,需要完成以下准备工作:

环境准备。环境搭建。创建项目申请调试证书应用开发

具体操作,请按照《DevEco Studio使用指南》中详细说明来完成。

4. 代码编写

1. 在en-US.json和zh-CN.json文件中添加字符串资源参考代码


{
    "strings": {
        "male": "male",
        "female": "female",
        "secret": "secret",
        "graduated": "graduated",
        "bachelor": "bachelor",
        "master": "master",
        "doctor": "doctor"
    }
}



{
    "strings": {
        "male": "男",
        "female": "女",
        "secret": "保密",
        "graduated": "本科",
        "bachelor": "学士",
        "master": "硕士",
        "doctor": "博士"
    }
}


2. index.hml文件页面布局参考代码


<div class="container">
    <input class="title" onchange="getName" value="{{text}}" type="text"></input>
    <div class="title">
        <div class="radio-item">
            <input id="radio_male" type="radio" name="radio" value="{{ $t('strings.male') }}" onchange="getGender"></input>
            <label target="radio_male">{{ $t('strings.male') }}
            </label>
        </div>
        <div class="radio-item">
            <input id="radio_female" type="radio" name="radio" value="{{ $t('strings.female') }}"
                    onchange="getGender"></input>
            <label target="radio_female">{{ $t('strings.female') }}
            </label>
        </div>
        <div class="radio-item">
            <input id="radio_secret" type="radio" name="radio" value="{{ $t('strings.secret') }}"
                    onchange="getGender"></input>
            <label target="radio_secret">{{ $t('strings.secret') }}
            </label>
        </div>
    </div>
    <select class="title">
        <option value="{{$t('strings.graduated')}}">{{$t('strings.graduated')}}
        </option>
        <option value="{{$t('strings.bachelor')}}">{{$t('strings.bachelor')}}
        </option>
        <option value="{{$t('strings.master')}}">{{$t('strings.master')}}
        </option>
        <option value="{{$t('strings.doctor')}}">{{$t('strings.doctor')}}
        </option>
    </select>
</div>


3. index.css文件样式参考代码


.container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.title {
    font-size: 20px;
    flex-direction: column;
}

.radio-item {
    font-size: 30px;
    flex-direction: row;
}


4. index.js文件逻辑参考代码


export default {
    data: {
        text: "",
        today: "2020-08-26"
    },
    getName(e) {
        this.text = e.text;
        console.info("user name is " + e.text);
    },
    getGender(e) {
        console.info("gender is " + e.value);
    },
    getDate(e) {
        this.today = e.year + "-" + (e.month + 1) + "-" + e.day;
        console.info("date is " + e.year + "/" + (e.month + 1) + "/" + e.day);
    },
    onInit() {
        this.title = this.$t('strings.world');
    }
}


提示:以上代码仅demo演示参考使用,产品化的代码需要使用国际化

5. 编译运行


通过hdc连接大屏设备
先查看智慧屏IP:大屏设置->"网络与连接"->"网络"->"无线网络"

在cmd或者IDE的Terminal输入命令:


hdc tconn 192.168.xxx.xxx:5555

运行

HarmonyOS应用开发-基本控件-鸿蒙开发者社区

干得好
你已经成功完成了HarmonyOS应用开发E2E体验,学到了:
如何创建一个HarmonyOS Demo Project
如何构建一个Hap并且将其部署到真机上
在HarmonyOS上如何使用HarmonyOS的轻量级偏好数据库


©本站发布的所有内容,包括但不限于文字、图片、音频、视频、图表、标志、标识、广告、商标、商号、域名、软件、程序等,除特别标明外,均来源于网络或用户投稿,版权归原作者或原出处所有。我们致力于保护原作者版权,若涉及版权问题,请及时联系我们进行处理。
分类
其它
地址:北京市朝阳区北三环东路三元桥曙光西里甲1号第三置业A座1508室 商务内容合作QQ:2291221 电话:13391790444或(010)62178877
版权所有:电脑商情信息服务集团 北京赢邦策略咨询有限责任公司
声明:本媒体部分图片、文章来源于网络,版权归原作者所有,我司致力于保护作者版权,如有侵权,请与我司联系删除
京ICP备:2022009079号-2
京公网安备:11010502051901号
ICP证:京B2-20230255