鸿蒙开发接口资源管理:【@ohos.intl (国际化-Intl)】

server/2025/1/11 8:53:38/

国际化-Intl

icon-note.gif

 说明:
开发前请熟悉鸿蒙开发指导文档:gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md点击或者复制转到。

  • 本模块首批接口从API version 6开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
  • Intl模块包含国际化能力基础接口(在ECMA 402中定义)。

导入模块

import Intl from '@ohos.intl';

Locale

属性

系统能力:以下各项对应的系统能力均为SystemCapability.Global.I18n

名称参数类型可读可写说明
languagestring与区域设置关联的语, 如:zh。
scriptstring语言的书写方式,如:Hans。
regionstring与区域设置相关的地区,如:CN。
baseNamestringLocale的基本核心信息(由语言脚本与地区组成),如:zh-Hans-CN。
caseFirststring区域的整理规则是否考虑大小写,取值包括:"upper", "lower", "false"。
calendarstring区域的日历信息,取值包括:"buddhist", "chinese", "coptic","dangi", "ethioaa", "ethiopic", "gregory", "hebrew", "indian", "islamic", "islamic-umalqura", "islamic-tbla", "islamic-civil", "islamic-rgsa", "iso8601", "japanese", "persian", "roc", "islamicc"。
collationstring区域的排序规则,取值包括:"big5han", "compat", "dict", "direct", "ducet", "eor", "gb2312", "phonebk", "phonetic", "pinyin", "reformed", "searchjl", "stroke", "trad", "unihan", "zhuyin"。
hourCyclestring区域的时制信息,取值包括:"h12", "h23", "h11", "h24"。
numberingSystemstring区域使用的数字系统,取值包括:"adlm", "ahom", "arab", "arabext", "bali", "beng", "bhks", "brah", "cakm", "cham", "deva", "diak", "fullwide", "gong", "gonm", "gujr", "guru", "hanidec", "hmng", "hmnp", "java", "kali", "khmr", "knda", "lana", "lanatham", "laoo", "latn", "lepc", "limb", "mathbold", "mathdbl", "mathmono", "mathsanb", "mathsans", "mlym", "modi", "mong", "mroo", "mtei", "mymr", "mymrshan", "mymrtlng", "newa", "nkoo", "olck", "orya", "osma", "rohg", "saur", "segment", "shrd", "sind", "sinh", "sora", "sund", "takr", "talu", "tamldec", "telu", "thai", "tibt", "tirh", "vaii", "wara", "wcho"。
numericboolean是否对数字字符具有特殊的排序规则处理。

constructor8+

constructor()

创建区域对象

系统能力:SystemCapability.Global.I18n

示例:

var locale = new Intl.Locale();

constructor

constructor(locale: string, options?: LocaleOptions)

创建区域对象

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
localestring包含区域设置信息的字符串,包括语言以及可选的脚本和区域。
optionsLocaleOptions用于创建区域对象的选项。

示例:

var locale = new Intl.Locale("zh-CN");

toString

toString(): string

将区域信息转换为字符串

系统能力:SystemCapability.Global.I18n

返回值:

类型说明
string字符串形式的区域信息。

示例:

var locale = new Intl.Locale("zh-CN");
locale.toString();

maximize

maximize(): Locale

最大化区域信息,若缺少脚本与地区信息,则补齐。

系统能力:SystemCapability.Global.I18n

返回值:

类型说明
[Locale]最大化后的区域对象。

示例:

var locale = new Intl.Locale("zh-CN");
locale.maximize();

minimize

minimize(): Locale

最小化区域信息,若包含脚本与地区信息,则去除。

系统能力:SystemCapability.Global.I18n

返回值:

类型说明
[Locale]最小化后的区域对象。

示例:

var locale = new Intl.Locale("zh-CN");
locale.minimize();

LocaleOptions

表示区域初始化选项。

系统能力:以下各项对应的系统能力均为SystemCapability.Global.I18n

名称参数类型可读可写说明
calendarstring日历参数,如:"buddhist", "chinese", "coptic", "dangi", "ethioaa", "ethiopic", "gregory", "hebrew", "indian", "islamic", "islamic-umalqura", "islamic-tbla", "islamic-civil", "islamic-rgsa", "iso8601", "japanese", "persian", "roc", "islamicc"。
collationstring排序参数,取值包括:"big5han", "compat", "dict", "direct", "ducet", "emoji", "eor", "gb2312", "phonebk", "phonetic", "pinyin", "reformed ", "search", "searchjl", "standard", "stroke", "trad", "unihan", "zhuyin"。
hourCyclestring时制格式,取值包括:"h11", "h12", "h23", "h24"。
numberingSystemstring数字系统,取值包括:"adlm", "ahom", "arab", "arabext", "bali", "beng", "bhks", "brah", "cakm", "cham", "deva", "diak", "fullwide", "gong", "gonm", "gujr", "guru", "hanidec", "hmng", "hmnp", "java", "kali", "khmr", "knda", "lana", "lanatham", "laoo", "latn", "lepc", "limb", "mathbold", "mathdbl", "mathmono", "mathsanb", "mathsans", "mlym", "modi", "mong", "mroo", "mtei", "mymr", "mymrshan", "mymrtlng", "newa", "nkoo", "olck", "orya", "osma", "rohg", "saur", "segment", "shrd", "sind", "sinh", "sora", "sund", "takr", "talu", "tamldec", "telu", "thai", "tibt", "tirh", "vaii", "wara", "wcho"。
numericboolean是否使用12小时制。
caseFirststring表示大写、小写的排序顺序,取值范围:"upper", "lower", "false"。

DateTimeFormat

constructor8+

constructor()

创建时间日期格式化对象。

系统能力:SystemCapability.Global.I18n

示例:

var datefmt= new Intl.DateTimeFormat();

constructor

constructor(locale: string | Array<string>, options?: DateTimeOptions)

创建时间日期格式化对象。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
localestringArray<string>包含区域设置信息的字符串,包括语言以及可选的脚本和区域。
options[DateTimeOptions]用于创建时间日期格式化的选项。

示例:

var datefmt= new Intl.DateTimeFormat("zh-CN", { dateStyle: 'full', timeStyle: 'medium' });

示例:

var datefmt= new Intl.DateTimeFormat(["ban", "zh"], { dateStyle: 'full', timeStyle: 'medium' });

format

format(date: Date): string

格式化时间日期字符串。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
dateDate时间日期对象。

返回值:

类型说明
string格式化后的时间日期字符串

示例:

var date = new Date(2021, 11, 17, 3, 24, 0);
var datefmt = new Intl.DateTimeFormat("en-GB");
datefmt.format(date);

formatRange

formatRange(startDate: Date, endDate: Date): string

格式化时间日期段字符串。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
startDateDate起始的时间日期。
endDateDate结束的时间日期。

返回值:

类型说明
string格式化后的时间日期段字符串。

示例:

var startDate = new Date(2021, 11, 17, 3, 24, 0);
var endDate = new Date(2021, 11, 18, 3, 24, 0);
var datefmt = new Intl.DateTimeFormat("en-GB");
datefmt.formatRange(startDate, endDate);

resolvedOptions

resolvedOptions(): DateTimeOptions

获取DateTimeFormat对象的格式化选项。

系统能力:SystemCapability.Global.I18n

返回值:

类型说明
[DateTimeOptions]DateTimeFormat 对象的格式化选项。

示例:

var datefmt = new Intl.DateTimeFormat("en-GB");
datefmt.resolvedOptions();

DateTimeOptions

表示时间日期格式化选项。

系统能力:以下各项对应的系统能力均为SystemCapability.Global.I18n

名称参数类型可读可写说明
localestring区域参数, 如:zh-Hans-CN。
dateStylestring日期显示格式,取值包括:"long", "short", "medium", "full"。
timeStylestring时间显示格式,取值包括:"long", "short", "medium", "full"。
hourCyclestring时制格式,取值包括:"h11", "h12", "h23", "h24"。
timeZonestring使用的时区(合法的IANA时区ID)。
numberingSystemstring数字系统,取值包括:"adlm", "ahom", "arab", "arabext", "bali", "beng", "bhks", "brah", "cakm", "cham", "deva", "diak", "fullwide", "gong", "gonm", "gujr", "guru", "hanidec", "hmng", "hmnp", "java", "kali", "khmr", "knda", "lana", "lanatham", "laoo", "latn", "lepc", "limb", "mathbold", "mathdbl", "mathmono", "mathsanb", "mathsans", "mlym", "modi", "mong", "mroo", "mtei", "mymr", "mymrshan", "mymrtlng", "newa", "nkoo", "olck", "orya", "osma", "rohg", "saur", "segment", "shrd", "sind", "sinh", "sora", "sund", "takr", "talu", "tamldec", "telu", "thai", "tibt", "tirh", "vaii", "wara", "wcho"。
hour12boolean是否使用12小时制。
weekdaystring工作日的显示格式,取值包括:"long", "short", "narrow"。
erastring时代的显示格式,取值包括:"long", "short", "narrow"。
yearstring年份的显示格式,取值包括:"numeric", "2-digit"。
monthstring月份的显示格式,取值包括:"numeric", "2-digit", "long", "short", "narrow"。
daystring日期的显示格式,取值包括:"numeric", "2-digit"。
hourstring小时的显示格式,取值包括:"numeric", "2-digit"。
minutestring分钟的显示格式,取值包括:"numeric", "2-digit"。
secondstring秒钟的显示格式,取值包括:"numeric", "2-digit"。
timeZoneNamestring时区名称的本地化表示。
dayPeriodstring时段的显示格式,取值包括:"long", "short", "narrow"。
localeMatcherstring要使用的区域匹配算法,取值包括:"lookup", "best fit"。
formatMatcherstring要使用的格式匹配算法,取值包括:"basic", "best fit"。

NumberFormat

constructor8+

constructor()

创建数字格式化对象。

系统能力:SystemCapability.Global.I18n

示例:

var numfmt = new Intl.NumberFormat();

constructor

constructor(locale: string | Array<string>, options?: NumberOptions)

创建数字格式化对象。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
localestringArray<string>包含区域设置信息的字符串,包括语言以及可选的脚本和区域。
options[NumberOptions]用于创建数字格式化的选项。

示例:

var numfmt = new Intl.NumberFormat("en-GB", {style:'decimal', notation:"scientific"});

format

format(number: number): string;

格式化数字字符串。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
numbernumber数字对象

返回值:

类型说明
string格式化后的数字字符串

示例:

var numfmt = new Intl.NumberFormat(["en-GB", "zh"], {style:'decimal', notation:"scientific"});
numfmt.format(1223);

resolvedOptions

resolvedOptions(): NumberOptions

获取NumberFormat 对象的格式化选项。

系统能力:SystemCapability.Global.I18n

返回值:

类型说明
[NumberOptions]NumberFormat 对象的格式化选项。

示例:

var numfmt = new Intl.NumberFormat(["en-GB", "zh"], {style:'decimal', notation:"scientific"});
numfmt.resolvedOptions();

NumberOptions

表示设备支持的能力。

系统能力:以下各项对应的系统能力均为SystemCapability.Global.I18n

名称参数类型可读可写说明
localestring区域参数, 如:"zh-Hans-CN"。
currencystring货币单位, 如:"EUR","CNY","USD"等。
currencySignstring货币单位的符号显示,取值包括: "symbol","narrowSymbol","code","name" 。
currencyDisplaystring货币的显示方式,取值包括:"symbol", "narrowSymbol", "code", "name"。
unitstring单位名称,如:"meter","inch",“hectare”等。
unitDisplaystring单位的显示格式,取值包括:"long", "short", "narrow"。
unitUsage8+string单位的使用场景,取值包括:"default", "area-land-agricult", "area-land-commercl", "area-land-residntl", "length-person", "length-person-small", "length-rainfall", "length-road", "length-road-small", "length-snowfall", "length-vehicle", "length-visiblty", "length-visiblty-small", "length-person-informal", "length-person-small-informal", "length-road-informal", "speed-road-travel", "speed-wind", "temperature-person", "temperature-weather", "volume-vehicle-fuel"。
signDisplaystring数字符号的显示格式,取值包括:"auto", "never", "always", "expectZero"。
compactDisplaystring紧凑型的显示格式,取值包括:"long", "short"。
notationstring数字的格式化规格,取值包括:"standard", "scientific", "engineering", "compact"。
localeMatcherstring要使用的区域匹配算法,取值包括:"lookup", "best fit"。
stylestring数字的显示格式,取值包括:"decimal", "currency", "percent", "unit"。
numberingSystemstring数字系统,取值包括:"adlm", "ahom", "arab", "arabext", "bali", "beng", "bhks", "brah", "cakm", "cham", "deva", "diak", "fullwide", "gong", "gonm", "gujr", "guru", "hanidec", "hmng", "hmnp", "java", "kali", "khmr", "knda", "lana", "lanatham", "laoo", "latn", "lepc", "limb", "mathbold", "mathdbl", "mathmono", "mathsanb", "mathsans", "mlym", "modi", "mong", "mroo", "mtei", "mymr", "mymrshan", "mymrtlng", "newa", "nkoo", "olck", "orya", "osma", "rohg", "saur", "segment", "shrd", "sind", "sinh", "sora", "sund", "takr", "talu", "tamldec", "telu", "thai", "tibt", "tirh", "vaii", "wara", "wcho"。
useGroupingboolean是否分组显示。
minimumIntegerDigitsnumber表示要使用的最小整数位数,取值范围:1~21。
minimumFractionDigitsnumber表示要使用的最小分数位数,取值范围:0~20。
maximumFractionDigitsnumber表示要使用的最大分数位数,取值范围:1~21。
minimumSignificantDigitsnumber表示要使用的最低有效位数,取值范围:1~21。
maximumSignificantDigitsnumber表示要使用的最大有效位数,取值范围:1~21。

Collator8+

constructor8+

constructor()

创建排序对象。

系统能力:SystemCapability.Global.I18n

示例:

var collator = new Intl.Collator();

constructor8+

constructor(locale: string | Array<string>, options?: CollatorOptions)

创建排序对象。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
localestringArray<string>包含区域设置信息的字符串,包括语言以及可选的脚本和区域。
options[CollatorOptions]用于创建排序对象的选项。

示例:

var collator = new Intl.Collator("zh-CN", {localeMatcher: "lookup", usage: "sort"});

compare8+

compare(first: string, second: string): number

依据Collator的排序策略对两个字符串进行比较。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
firststring进行比较第一个字符串。
secondstring进行比较的第二个字符串。

返回值:

类型说明
number比较结果。当number为负数,表示first排序在second之前;当number为0,表示first与second排序相同;当number为正数,表示first排序在second之后。

示例:

var collator = new Intl.Collator("zh-Hans");
collator.compare("first", "second");

resolvedOptions8+

resolvedOptions(): CollatorOptions

返回Collator对象的属性。

系统能力:SystemCapability.Global.I18n

返回值:

类型说明
[CollatorOptions]返回的Collator对象的属性。

示例:

var collator = new Intl.Collator("zh-Hans");
var options = collator.resolvedOptions();

CollatorOptions8+[]()

表示Collator可设置的属性。

系统能力:以下各项对应的系统能力均为SystemCapability.Global.I18n

名称参数类型可读可写说明
localeMatcherstringlocale匹配算法,取值范围:"best fit", "lookup"。
usagestring比较的用途,取值范围:"sort", "search"。
sensitivitystring表示字符串中的哪些差异会导致非零结果值,取值范围:"base", "accent", "case", "variant"。
ignorePunctuationboolean表示是否忽略标点符号,取值范围:true, false。
collationstring排序规则,取值范围:"big5han", "compat", "dict", "direct", "ducet", "eor", "gb2312", "phonebk", "phonetic", "pinyin", "reformed", "searchjl", "stroke", "trad", "unihan", "zhuyin"。
numericboolean是否使用数字排序,取值范围:true, false。
caseFirststring表示大写、小写的排序顺序,取值范围:"upper", "lower", "false"。

PluralRules8+

constructor8+

constructor()

创建PluralRules对象。

系统能力:SystemCapability.Global.I18n

示例:

var pluralRules = new Intl.PluralRules();

constructor8+

constructor(locale: string | Array<string>, options?: PluralRulesOptions)

创建PluralRules对象。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
localestringArray<string>包含区域设置信息的字符串,包括语言以及可选的脚本和区域。
options[PluralRulesOptions]用于创建单复数对象的选项。

示例:

var pluralRules= new Intl.PluraRules("zh-CN", {"localeMatcher": "lookup", "type": "cardinal"});

select8+

select(n: number): string

返回一个字符串表示该数字的单复数类别。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
nnumber待获取单复数类别的数字。

返回值:

类型说明
string单复数类别,取值包括:"zero","one","two", "few", "many", "others"。

示例:

var pluralRules = new Intl.PluralRules("zh-Hans");
pluralRules.select(1);

PluralRulesOptions8+[]()

表示PluralRules对象可设置的属性。

系统能力:以下各项对应的系统能力均为SystemCapability.Global.I18n

名称参数类型可读可写说明
localeMatcherstringlocale匹配算法,取值包括:"best fit", "lookup"。
typestring排序的类型,取值包括:"cardinal", "ordinal"。
minimumIntegerDigitsnumber表示要使用的最小整数位数,取值范围:1~21。
minimumFractionDigitsnumber表示要使用的最小分数位数,取值范围:0~20。
maximumFractionDigitsnumber表示要使用的最大分数位数,取值范围:1~21。
minimumSignificantDigitsnumber表示要使用的最低有效位数,取值范围:1~21。
maximumSignificantDigitsnumber表示要使用的最大有效位数,取值范围:1~21。

RelativeTimeFormat8+

constructor8+

constructor()

创建相对时间格式化对象。

系统能力:SystemCapability.Global.I18n

示例:

var relativetimefmt = new Intl.RelativeTimeFormat();

constructor8+

constructor(locale: string | Array<string>, options?: RelativeTimeFormatInputOptions)

创建相对时间格式化对象。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
localestringArray<string>包含区域设置信息的字符串,包括语言以及可选的脚本和区域。
options[RelativeTimeFormatInputOptions]用于创建相对时间格式化对象的选项。

示例:

var relativeTimeFormat = new Intl.RelativeTimeFormat("zh-CN", {"localeMatcher": "lookup", "numeric": "always", "style": "long"});

format8+

format(value: number, unit: string): string

依据locale和格式化选项,对value和unit进行格式化。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
valuenumber相对时间格式化的数值。
unitstring相对时间格式化的单位,取值包括:"year", "quarter", "month", "week", "day", "hour", "minute", "second"。

返回值:

类型说明
string格式化后的相对时间。

示例:

var relativetimefmt = new Intl.RelativeTimeFormat("zh-CN");
relativetimefmt.format(3, "quarter")

formatToParts8+

formatToParts(value: number, unit: string): Array<object>

返回一个对象数组,表示可用于自定义区域设置格式的相对时间格式。

系统能力:SystemCapability.Global.I18n

参数:

参数名类型必填说明
valuenumber相对时间格式化的数值。
unitstring相对时间格式化的单位,取值包括:"year", "quarter", "month", "week", "day", "hour", "minute", "second"。

返回值:

类型说明
Array<object>返回可用于自定义区域设置格式的相对时间格式的对象数组。

示例:

var relativetimefmt = new Intl.RelativeTimeFormat("en", {"numeric": "auto"});
var parts = relativetimefmt.format(10, "seconds");

resolvedOptions8+

resolvedOptions(): RelativeTimeFormatResolvedOptions

获取RelativeTimeFormat对象的格式化选项。

系统能力:SystemCapability.Global.I18n

返回值:

类型说明
[RelativeTimeFormatResolvedOptions]RelativeTimeFormat 对象的格式化选项。

示例:

var relativetimefmt= new Intl.RelativeTimeFormat("en-GB");
relativetimefmt.resolvedOptions();

RelativeTimeFormatInputOptions8+[]()

表示RelativeTimeFormat对象可设置的属性。

系统能力:以下各项对应的系统能力均为SystemCapability.Global.I18n

名称参数类型可读可写说明
localeMatcherstringlocale匹配算法,取值包括:"best fit", "lookup"。
numericstring输出消息的格式,取值包括:"always", "auto"。
stylestring国际化消息的长度,取值包括:"long", "short", "narrow"。

RelativeTimeFormatResolvedOptions8+[]()

表示RelativeTimeFormat对象可设置的属性。

系统能力:以下各项对应的系统能力均为SystemCapability.Global.I18n

新文档.png

名称参数类型可读可写说明 HarmonyOS与OpenHarmony鸿蒙文档籽料:mau123789是v直接拿
localestring包含区域设置信息的字符串,包括语言以及可选的脚本和区域。
numericstring输出消息的格式,取值包括:"always", "auto"。
stylestring国际化消息的长度,取值包括:"long", "short", "narrow"。
numberingSystemstring使用的数字系统。

http://www.ppmy.cn/server/46843.html

相关文章

vs code怎么补全路径,怎么快捷输入文件路径

安装插件&#xff1a; 链接&#xff1a;https://marketplace.visualstudio.com/items?itemNamejakob101.RelativePath 使用 按住 Ctrl Shift H&#xff0c;弹出窗口&#xff0c;输入文件补全&#xff0c;回车就可以了 排除文件 如果你的项目下文件太多&#xff0c;它会…

SSMP整合案例第五步 在前端页面上拿到service层调数据库里的数据后列表

在前端页面上列表 我们首先看看前端页面 我们已经把数据传入前端控制台 再看看我们的代码是怎么写的 我们展示 数据来自图dataList 在这里 我们要把数据填进去 就能展示在前端页面上 用的是前端数据双向绑定 axios发送异步请求 函数 //钩子函数&#xff0c;VUE对象初始化…

单线程 vs 多进程:Python网络爬虫效率对比

概述 在网络爬虫的开发过程中&#xff0c;性能优化是一个重要的考虑因素。本文将概述单线程和多进程在Python网络爬虫中的应用&#xff0c;并对比它们的效率。 单线程爬虫是最基本的爬虫模型&#xff0c;它按顺序一个接一个地处理任务。这种方法的优点是实现简单&#xff0c;易…

C++一个StringBad类

设计一个字符串类,下面的代码是一个不好的设计,起名StringBad。 //stringbad.h #pragma once //一个设计有问题的string类 #include <iostream> using namespace std;class StringBad { public:StringBad();//默认构造函数StringBad(const char* s);//构造函数~StringBa…

YOLOv5训练数据集的配置文件格式与使用技巧

文章目录 一 概述二 配置文件说明2.1 官方配置文件解析2.2 自定义数据集配置文件2.3 其他格式指定数据集路径2.4 多个数据集路径指定 三 总结注意事项 一 概述 本文档主要记录 YOLOv5 算法在进行模型训练前&#xff0c;关于加载数据集的配置文件的说明。 默认情况下&#xff…

Chromium源码学习(1)—— 拉取源码,编译

阅读建议&#xff1a;先简单过一下整个文章目录结构&#xff0c;大致了解一下各个步骤在干什么&#xff0c;然后在上手操作可能会事半功倍。也许你遇到的有些问题文章中已经提及到了&#xff0c;但是由于你没有往下看导致卡进度。 Chromium简介 Chromium项目于2008年发布&…

GPU学习(1)

一、为什么要GPU 我们先看一个基本的神经网络计算 YF(x)AxB 这就是一次乘法一次加法 &#xff0c;也叫FMA&#xff0c;(fused multiply-add) 如果矩阵乘&#xff0c;就是上面的那个式子扩展一下&#xff0c;所以又用了这张老图 比如你要多执行好几个yAxB&#xff0c;可能比较简…

【前端开发--css学习笔记】CSS超详细的学习笔记。前端开发css学习笔记(非常详细,适合小白入门)

二&#xff0c;CSS学习笔记 1&#xff0c;CSS语法 1-1 CSS 实例 CSS声明总是以分号 ; 结束&#xff0c;声明总以大括号 {} 括起来: <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>菜鸟教程(runoob.com)</title…