HarmonyOS Next快速入门:类型定义和国际化

##HarmonyOS Next快速入门##HarmonyOS应用开发##教育##

点击跳转《HarmonyOS Next快速入门》视频教程

Resource 资源引用类型,用于设置组件属性的值。

可以通过r或者rawfile创建Resource类型对象,不可以修改Resource中的各属性的值。

typescript 复制代码
$r('belonging.type.name')
//belonging:系统资源或者应用资源,相应的取值为'sys'和'app';
//type:资源类型,支持'string'、'color'、'boolean'、'float'、'intarray'、'integer'、'pattern'、'plural'、'strarray'、'media';
//name:资源名称,在资源定义时确定。

$rawfile('filename')
//filename:工程中resources/rawfile目录下的文件名称。

推荐大家优先使用Resource类型,将资源文件(字符串、图片、音频等)统一存放于resources目录下,便于开发者统一维护。同时系统可以根据当前配置加载合适的资源,例如,开发者可以根据屏幕尺寸呈现不同的布局效果,或根据语言设置提供不同的字符串。

颜色代码参考:

typescript 复制代码
https://www.runoob.com/cssref/css-colornames.html

代码实例:ResourcePage

typescript 复制代码
@Entry
@Component
struct ResourcePage {
  @State message: string = 'Resource';

  build() {
    Column() {
      Text(this.message)
        .fontSize(30)
        .fontWeight(FontWeight.Bold)

      Button($r('app.string.label_login')).backgroundColor($r('app.color.btn_color'))

      Image($rawfile('cat.jpg')).size({width:100})
    }
    .height('100%')
    .width('100%')
  }
}

国际化@ohos.i18n 本模块提供系统相关的或者增强的国际化能力,包括区域管理、电话号码处理、日历等,相关接口为ECMA 402标准中未定义的补充接口。Intl模块提供了ECMA 402标准定义的基础国际化接口,与本模块共同使用可提供完整地国际化支持能力。

导入模块

typescript 复制代码
import { i18n } from '@kit.LocalizationKit';

文本按指定国家进行本地化显示。

typescript 复制代码
static getDisplayCountry(country: string, locale: string, sentenceCase?: boolean): string

代码实例

typescript 复制代码
import { BusinessError } from '@kit.BasicServicesKit';

try {
    let displayCountry: string = i18n.System.getDisplayCountry("zh-CN", "en-GB"); // displayCountry = "China"
} catch (error) {
    let err: BusinessError = error as BusinessError;
    console.error(`call System.getDisplayCountry failed, error code: ${err.code}, message: ${err.message}.`);
}

文本按指定语言进行本地化显示。

typescript 复制代码
static getDisplayLanguage(language: string, locale: string, sentenceCase?: boolean): string

代码示例

typescript 复制代码
import { BusinessError } from '@kit.BasicServicesKit';

try {
  let displayLanguage: string = i18n.System.getDisplayLanguage("zh", "en-GB"); // 用英文形式显示中文,displayLanguage = Chinese
} catch(error) {
  let err: BusinessError = error as BusinessError;
  console.error(`call System.getDisplayLanguage failed, error code: ${err.code}, message: ${err.message}.`);
}

针对输入语言,系统支持的国家或地区列表。

typescript 复制代码
static getSystemCountries(language: string): Array<string>

代码实例

typescript 复制代码
import { BusinessError } from '@kit.BasicServicesKit';

try {
  let systemCountries: Array<string> = i18n.System.getSystemCountries('zh'); // systemCountries = [ "ZW", "YT", "YE", ..., "ER", "CN", "DE" ]
} catch(error) {
  let err: BusinessError = error as BusinessError;
  console.error(`call System.getSystemCountries failed, error code: ${err.code}, message: ${err.message}.`);
}

判断当前语言和地区是否匹配。

typescript 复制代码
static isSuggested(language: string, region?: string): boolean

代码实例

typescript 复制代码
import { BusinessError } from '@kit.BasicServicesKit';

try {
  let res: boolean = i18n.System.isSuggested('zh', 'CN');  // res = true
} catch(error) {
  let err: BusinessError = error as BusinessError;
  console.error(`call System.isSuggested failed, error code: ${err.code}, message: ${err.message}.`);
}

设置应用的偏好语言。设置偏好语言为"default"后,应用语言将跟随系统语言,应用冷启动生效。

typescript 复制代码
static setAppPreferredLanguage(language: string): void

代码实例

typescript 复制代码
import { BusinessError } from '@kit.BasicServicesKit';

try {
  i18n.System.setAppPreferredLanguage('zh'); // 设置应用当前的偏好语言为 "zh"
} catch(error) {
  let err: BusinessError = error as BusinessError;
  console.error(`call System.setAppPreferredLanguage failed, error code: ${err.code}, message: ${err.message}.`);
}
相关推荐
Georgewu1 小时前
【HarmonyOS 6】 The target can not be empty. check the build.profile,json5 file of
harmonyos
Georgewu1 小时前
【HarmonyOS 6】Install Failed: error: failed to install bundle.code:9568322
harmonyos
爱笑的眼睛113 小时前
HarmonyOS 应用开发新范式:深入剖析 Stage 模型与 ArkTS 状态管理
华为·harmonyos
爱笑的眼睛114 小时前
深入浅出 HarmonyOS ArkUI 3.0:基于声明式开发范式与高级状态管理构建高性能应用
华为·harmonyos
程序员潘Sir7 小时前
鸿蒙应用开发从入门到实战(一):鸿蒙应用开发概述
harmonyos
敲代码的鱼哇11 小时前
跳转原生系统设置插件 支持安卓/iOS/鸿蒙UTS组件
android·ios·harmonyos
在下历飞雨11 小时前
Kuikly基础之状态管理与数据绑定:让“孤寡”计数器动起来
ios·harmonyos
在下历飞雨11 小时前
Kuikly基础之Kuikly DSL基础组件实战:构建青蛙主界面
ios·harmonyos
HarmonyOS小助手13 小时前
HEIF:更高质量、更小体积,开启 HarmonyOS 图像新体验
harmonyos·鸿蒙·鸿蒙生态
self_myth14 小时前
[特殊字符] 深入理解操作系统核心特性:从并发到分布式,从单核到多核的全面解析
windows·macos·wpf·harmonyos