版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
HarmonyOS簡(jiǎn)介了解鴻蒙鴻蒙發(fā)展歷史了解OpenHarmonyOpenHarmony是由開(kāi)放原子開(kāi)源基金會(huì)(OpenAtomFoundation)孵化及運(yùn)營(yíng)的開(kāi)源項(xiàng)目,目標(biāo)是面向全場(chǎng)景、全連接、全智能時(shí)代,基于開(kāi)源的方式,搭建一個(gè)智能終端設(shè)備操作系統(tǒng)的框架和平臺(tái),促進(jìn)萬(wàn)物互聯(lián)產(chǎn)業(yè)的繁榮發(fā)展。OpenHarmony提供一個(gè)智能終端設(shè)備的操作系統(tǒng)底座框架和平臺(tái),參與者只要遵循開(kāi)源協(xié)議和法律,就可以持續(xù)為OpenHarmony開(kāi)源項(xiàng)目貢獻(xiàn)代碼,共同促進(jìn)萬(wàn)物全場(chǎng)景、全連接、全智能的互聯(lián)產(chǎn)業(yè)的繁榮發(fā)展。項(xiàng)目地址為:/openharmony。
了解HarmonyOSHarmonyOS就是鴻蒙操作系統(tǒng),是商用版本,是華為基于OpenHarmony、AOSP(AndroidOpenSourceProject)等開(kāi)源項(xiàng)目推出的新一代智能終端操作系統(tǒng),HarmonyOS手機(jī)和平板也能運(yùn)行Android應(yīng)用,是因?yàn)镠armonyOS遵循了Android的AOSP。HarmonyOS系統(tǒng)架構(gòu)HarmonyOS整體遵從分層設(shè)計(jì),從下向上依次為:內(nèi)核層、系統(tǒng)服務(wù)層、框架層和應(yīng)用層。1+8+N全場(chǎng)景應(yīng)用HarmonyOS是一個(gè)支持多設(shè)備的操作系統(tǒng),“一生萬(wàn)物,萬(wàn)物歸一”。HarmonyOS以手機(jī)為核心,將生活場(chǎng)景中的各類終端進(jìn)行能力整合,構(gòu)建1+8+N全場(chǎng)景應(yīng)用,實(shí)現(xiàn)不同終端設(shè)備之間的快速連接、服務(wù)流轉(zhuǎn)、能力互助、資源共享,匹配合適的設(shè)備、提供流暢的全場(chǎng)景體驗(yàn)。開(kāi)發(fā)前準(zhǔn)備了解DevEcoStudioHUAWEIDevEcoStudio(簡(jiǎn)稱DevEcoStudio)是面向華為終端全場(chǎng)景多設(shè)備的一站式集成開(kāi)發(fā)環(huán)境(IDE),除了創(chuàng)建工程、開(kāi)發(fā)、編譯、調(diào)試、發(fā)布等功能外,DevEcoStudio還可以支持多設(shè)備開(kāi)發(fā),實(shí)時(shí)預(yù)覽器/模擬器等。DevEcoStudio支持多設(shè)備預(yù)覽、模擬器運(yùn)行、真機(jī)運(yùn)行三種方式。開(kāi)發(fā)者可以在DevEcoStudio中使用遠(yuǎn)程模擬器(RemoteEmulator)運(yùn)行應(yīng)用,也可以下載本地模擬器(LocalEmulator)運(yùn)行應(yīng)用,開(kāi)發(fā)者還可以使用超級(jí)終端模擬器(SuperDevice)調(diào)測(cè)跨設(shè)備的應(yīng)用。搭建開(kāi)發(fā)環(huán)境流程DevEcoStudio支持Windows系統(tǒng)和macOS系統(tǒng),在開(kāi)發(fā)HarmonyOS應(yīng)用/服務(wù)前,需要配置HarmonyOS應(yīng)用/服務(wù)的開(kāi)發(fā)環(huán)境。Node.js與npmNode.js是什么?Node.js是一個(gè)基于GoogleV8引擎開(kāi)發(fā)的C++程序Javascript運(yùn)行環(huán)境(runtime),具有事件驅(qū)動(dòng)、非阻塞I/O的特點(diǎn)。Node.js的優(yōu)點(diǎn)響應(yīng)速度快易于擴(kuò)展適合在分布式設(shè)備上運(yùn)行數(shù)據(jù)密集型的實(shí)時(shí)應(yīng)用npm
是
NodePackageManager的縮寫,意思是Node.js的包管理系統(tǒng)。安裝了Node.js后,自動(dòng)會(huì)安裝npm。認(rèn)識(shí)DevEcoStudio界面認(rèn)識(shí)TypeScript01020304JavaScript和TypeScript概述TypeScript程序的編譯與運(yùn)行TypeScript語(yǔ)法說(shuō)明TypeScript變量聲明JavaScript與ES6JavaScript語(yǔ)言(簡(jiǎn)稱“JS”)解釋型腳本語(yǔ)言廣泛應(yīng)用在Web端、移動(dòng)端、小程序端、桌面端、服務(wù)端動(dòng)態(tài)類型語(yǔ)言ES6(全稱“ECMAScript6.0”)JavaScript的一個(gè)版本標(biāo)準(zhǔn)2015年6月,ES6版本正式成為國(guó)際標(biāo)準(zhǔn)TypeScript簡(jiǎn)介TypeScript(簡(jiǎn)稱“TS”)微軟開(kāi)發(fā)的一種開(kāi)放源代碼語(yǔ)言JS的一個(gè)超集提供編譯時(shí)的靜態(tài)類型檢查ArkTS鴻蒙生態(tài)的一種應(yīng)用開(kāi)發(fā)語(yǔ)言TS的一個(gè)超集擴(kuò)展了聲明式UI、狀態(tài)管理等相應(yīng)的能力JS、TS、ArkTS三者關(guān)系TypeScript程序的編譯和運(yùn)行編譯使用tsc命令將TS文件.ts編譯成JS文件例如:tsctest.ts運(yùn)行使用node命令執(zhí)行編譯生成的JS文件例如:nodetest.jsTypeScript語(yǔ)法說(shuō)明TypeScript是面向?qū)ο笳Z(yǔ)言,與C?;騄ava類似。相同之處:可以使用數(shù)據(jù)類型定義變量具有函數(shù)、類、接口、枚舉等類型。不同之處:TS結(jié)束語(yǔ)句可以使用分號(hào)也可以不使用分號(hào)TS字符串可以使用單引號(hào)也可以使用雙引號(hào)示例:TypeScript變量聲明TypeScript變量的命名規(guī)則:變量名稱可以包含數(shù)字和字母;除了下劃線_和美元$符號(hào)外,不能包含其他特殊字符,包括空格;變量名不能以數(shù)字開(kāi)頭;不能是關(guān)鍵字,例如let、const等示例:正確的變量命名:message、$name、_init錯(cuò)誤的變量命名:123、123message、user/name!fruit1amilk%$age_value思考一下:以下哪些變量命名是正確的:TypeScript變量聲明聲明變量使用的關(guān)鍵字:var或let(建議使用let)TypeScript聲明變量方式的幾種情況:let[變量名]:[類型]=值;
使用示例:letuname:string="hello";let[變量名]:[類型];
使用示例:letuname:string;let[變量名]=值;
使用示例:letuname="hello";let[變量名];
使用示例:letuname;TypeScript變量聲明TypeScript在編譯時(shí)進(jìn)行類型檢查,遵循強(qiáng)類型,如果將不同的類型賦值給變量會(huì)編譯錯(cuò)誤。示例代碼如下://聲明變量val,并賦初始值let
val
=
123;//使用變量val
=
456
;
//正確console.log(val);//在控制臺(tái)打印出變量val的值val
=
'deg';
//編譯錯(cuò)誤TypeScript常用基礎(chǔ)數(shù)據(jù)類型TypeScript的常用基礎(chǔ)數(shù)據(jù)類型TypeScript的常用基礎(chǔ)數(shù)據(jù)類型有:any(任意類型)number(數(shù)字類型)string(字符串類型)boolean(布爾類型)數(shù)組類型tuple(元組類型)enum(枚舉類型)void類型null和undefined類型never類型TypeScript的常用基礎(chǔ)數(shù)據(jù)類型any類型聲明為any的變量可以賦予任意類型的值示例代碼如下:let
data:
any;
//聲明變量data為any類型data
=
"hello";
//將字符串賦值給dataconsole.log(typeof(data));
//輸出data的類型為stringTypeScript的常用基礎(chǔ)數(shù)據(jù)類型number類型number代表數(shù)字類型,是浮點(diǎn)值,它可以用來(lái)表示整數(shù)和小數(shù)。示例代碼如下:let
data:
number;
//聲明變量data為數(shù)字類型data
=
222;console.log(typeof(data));
//numberTypeScript的常用基礎(chǔ)數(shù)據(jù)類型string類型string代表字符串類型,使用單引號(hào)(‘)或雙引號(hào)(“)來(lái)表示字符串類型,反引號(hào)(`)來(lái)定義多行文本和內(nèi)嵌表達(dá)式,反引號(hào)中的${變量名}會(huì)替換成相應(yīng)的變量的值。示例代碼如下:let
data1:
string
=
"hello";
//聲明變量data為字符串類型let
data2
=
`${data1}`;
//使用反引號(hào),${變量名}會(huì)獲取到相應(yīng)變量的值console.log(data2);
//hello
TypeScript的常用基礎(chǔ)數(shù)據(jù)類型boolean類型boolean代表布爾類型,表示邏輯值:true和false。示例代碼如下:let
data:
boolean
=
true;
//聲明變量data為布爾類型TypeScript的常用基礎(chǔ)數(shù)據(jù)類型數(shù)組類型數(shù)組里放的都是類型相同的數(shù)據(jù)。有兩種方式可以定義數(shù)組。第一種,可以在元素類型后面接上[]。第二種使用數(shù)組泛型,Array<元素類型>。示例代碼如下://聲明變量datas為數(shù)組類型,數(shù)組中都是數(shù)字,聲明數(shù)組時(shí)同時(shí)初始化值let
datas:
number[]
=
[4,8,7];//聲明變量temps為數(shù)組泛型,數(shù)組中的數(shù)據(jù)類型是numberlet
temps:
Array<string>
=
["hi","ArkTS"];console.log(temps[1]);
//獲取temps數(shù)組的第2個(gè)成員的值,值為ArkTSTypeScript的常用基礎(chǔ)數(shù)據(jù)類型元組類型元組類型允許表示一個(gè)已知元素?cái)?shù)量和類型的數(shù)組,各元素的類型不必相同,初始化值時(shí)對(duì)應(yīng)位置的數(shù)據(jù)類型要相同。示例代碼如下:let
temps:
[number,string,boolean]
=
[2,'Hi',false];
//個(gè)數(shù)、類型、順序要一致temps
=
["UI",'HarmonyOS',true];//編譯報(bào)錯(cuò):不能將類型“string”分配給類型“number”TypeScript的常用基礎(chǔ)數(shù)據(jù)類型枚舉類型使用枚舉我們可以定義一些帶名字的常量。使用枚舉可以清晰地表達(dá)意圖或創(chuàng)建一組有區(qū)別的用例。TypeScript支持?jǐn)?shù)字的和基于字符串的枚舉。示例代碼如下:enum
DeviceType{
ZigBee,
LoRa}console.log(DeviceType.LoRa+"");//從枚舉類中取LoRa成員的值,值為1TypeScript的常用基礎(chǔ)數(shù)據(jù)類型void類型void類型一般用于聲明函數(shù)返回值類型它表示沒(méi)有任何類型。當(dāng)一個(gè)函數(shù)沒(méi)有返回值時(shí),你通常會(huì)見(jiàn)到其返回值類型是void。(void用來(lái)聲明的變量沒(méi)多大作用)。示例代碼如下:function
testFun():
void{
//函數(shù)沒(méi)有返回值
return
123;
//編譯報(bào)錯(cuò):不能將類型“number”分配給類型“void”}
TypeScript的常用基礎(chǔ)數(shù)據(jù)類型undefined與null類型undefined與null用作變量類型聲明用處不大,undefined一般用于變量未初始化時(shí)的默認(rèn)值,null變量用于給變量置空時(shí)使用。示例代碼如下:
let
cat;
//聲明變量cat,但沒(méi)有初始化
console.log(cat+"");
//undefined
cat
=
null;
if(null
==
cat)
{
console.log(cat+"");
//null
}TypeScript的常用基礎(chǔ)數(shù)據(jù)類型never類型never類型是其他類型的子類型,表示的是那些永不存在的值的類型。用在函數(shù)中,用來(lái)限制函數(shù)永遠(yuǎn)也執(zhí)行不到返回值的地方。示例代碼如下:function
testFun():
never{
//正確
while(true)
{
//…}
//while循環(huán)為恒真,永遠(yuǎn)也不會(huì)執(zhí)行到這里
}TypeScript的常用基礎(chǔ)數(shù)據(jù)類型聯(lián)合類型聯(lián)合類型使用管道符號(hào)(|)可以將變量聲明為多種類型,例如string|number表示字符串或者數(shù)值類型。示例代碼如下:let
x:
string|number;x
=
12;
//正確x
=
"haha"
;
//正確x
=
true;
//編譯報(bào)錯(cuò)TypeScript函數(shù)010203060504函數(shù)的定義與調(diào)用函數(shù)的返回值可選參數(shù)箭頭函數(shù)匿名函數(shù)默認(rèn)參數(shù)07函數(shù)聲明函數(shù)的定義與調(diào)用函數(shù)的定義使用function關(guān)鍵字修飾:函數(shù)名必須形參個(gè)數(shù)可選形參對(duì)應(yīng)的類型可選(形參沒(méi)有設(shè)置類型時(shí),使用any類型)形參之間使用逗號(hào)隔開(kāi)返回值類型可選(沒(méi)有指定返回值類型時(shí),返回值類型由返回值內(nèi)容確定)function函數(shù)名(形參1:類型1,形參2:類型2…):返回值類型{
//要執(zhí)行的代碼}函數(shù)的定義與調(diào)用函數(shù)的定義示例:functiontest()
{
console.log("hello")
//要執(zhí)行的代碼塊}函數(shù)的調(diào)用使用函數(shù)名()的形式調(diào)用函數(shù),若定義的函數(shù)有形參,則調(diào)用時(shí)要傳入實(shí)參。test()函數(shù)的返回值指定返回值類型時(shí),使用return返回該類型的返回值使用void修飾返回值類型時(shí),表示該函數(shù)沒(méi)有返回值,不能使用return//定義函數(shù),該函數(shù)的返回值類型為stringfunction
test100():
string{
return
"hi"
//返回一個(gè)string類型的結(jié)果}let
res_fun1:
string
=
test100();//調(diào)用函數(shù)并接收函數(shù)的返回值//定義函數(shù),該函數(shù)沒(méi)有返回值function
test200():
void{
return
"hi"
//編譯報(bào)錯(cuò)}函數(shù)的返回值//定義函數(shù),該函數(shù)的返回值未指明類型或void,則函數(shù)的返回值類型依情況而定function
test300(){
return
123
//返回一個(gè)number類型的值}let
res300:
number
=
test300();
//調(diào)用函數(shù)并接收函數(shù)的返回值沒(méi)有返回值類型修飾時(shí),可以返回任意類型的值,也可以不返回值。(函數(shù)的返回值類型由返回值決定)可選參數(shù)在TypeScript函數(shù)里,如果定義了參數(shù),則調(diào)用函數(shù)時(shí)必須傳入指定類型的參數(shù),除非將這些參數(shù)設(shè)置為可選??蛇x參數(shù)使用問(wèn)號(hào)(?)標(biāo)識(shí)可選參數(shù)必須跟在必須參數(shù)后面function
test(x:
string,
y?:
number)
//聲明一個(gè)有可選參數(shù)的函數(shù){
//要執(zhí)行的代碼
}test("hi");
//調(diào)用函數(shù),正確默認(rèn)參數(shù)當(dāng)定義了有參數(shù)的函數(shù),但是在調(diào)用函數(shù)的時(shí)候,如果不想傳入該參數(shù)的值,則使用默認(rèn)參數(shù)。function
test(x:
string,
y:
number
=
200)
//聲明一個(gè)有默認(rèn)值參數(shù)的函數(shù){
console.log(x+"
"+y);}test("hi");
//調(diào)用函數(shù),正確,y的值為200注意:同一個(gè)參數(shù)不能同時(shí)設(shè)置為可選和默認(rèn)。匿名函數(shù)匿名函數(shù)是一個(gè)沒(méi)有函數(shù)名的函數(shù),在程序運(yùn)行時(shí)動(dòng)態(tài)聲明,除了沒(méi)有函數(shù)名外,其他的與普通函數(shù)一樣。將匿名函數(shù)賦值給一個(gè)變量,這種表達(dá)式就是匿名函數(shù)表達(dá)式。let
res
=
function(a:
number,b:
number){
//定義一個(gè)帶參數(shù)的匿名函數(shù)
return
a+b;}console.log(res(4,5)+"");
//調(diào)用函數(shù),輸出:9匿名函數(shù)在匿名函數(shù)后使用()就是匿名函數(shù)的自調(diào)用。(function(){
console.log("我是自調(diào)用函數(shù)");})()
//匿名函數(shù)的自調(diào)用,輸出:我是自調(diào)用函數(shù)箭頭函數(shù)匿名函數(shù)的另一種簡(jiǎn)潔寫法就是箭頭函數(shù)的形式(使用=>定義函數(shù),也稱作lambda表達(dá)式)。/箭頭函數(shù):省略function關(guān)鍵字和函數(shù)名,使用=>let
res1
=
(x:number,y:
number)=>{
let
a
=
x+y;
console.log(a+"");}//定義有返回值的箭頭函數(shù),并且函數(shù)中有多行執(zhí)行語(yǔ)句let
res2
=
(x:number,y:
number):
string=>{
let
a
=
x+y;
console.log(a+"");
return
"ok"}//當(dāng)函數(shù)的執(zhí)行部分只有一行語(yǔ)句時(shí),{}可以省略let
res3
=
(x:number,y:
number)=>x+y//當(dāng)函數(shù)只有1個(gè)參數(shù),()可以省略let
res4
=
x=>x+100;//當(dāng)函數(shù)無(wú)參時(shí),可以使用空括號(hào):let
res5
=
()=>
100;重點(diǎn)函數(shù)的聲明函數(shù)聲明可以限定函數(shù)的名稱、參數(shù)類型和個(gè)數(shù)、函數(shù)的返回值等。//聲明函數(shù)myFun,有兩個(gè)參數(shù),返回值類型為string,聲明時(shí)同時(shí)賦值let
myFun:(x:number,y:string)=>string
=
(a:number,b:string)=>{return
b}//調(diào)用函數(shù)myFunmyFun(100,'HarmonyOS')TypeScript面向?qū)ο缶幊?10203面向?qū)ο缶幊谈攀鯰ypeScript中類的定義和對(duì)象的使用TypeScript中接口的聲明和使用面向?qū)ο缶幊蹋∣OP)概述面向?qū)ο?ObjectOriented)簡(jiǎn)稱OO,它是一種編程思維,用于指導(dǎo)我們?nèi)绾螒?yīng)對(duì)各種復(fù)雜的開(kāi)發(fā)場(chǎng)景。這里說(shuō)的對(duì)象(Object),意思就是事物,在面向?qū)ο蟮乃季S中,它將一切都看作是對(duì)象,并以對(duì)象為切入點(diǎn)去思考問(wèn)題。使用面向?qū)ο笏枷刖幊叹头Q作面向?qū)ο缶幊?ObjectOrientedProgramming),簡(jiǎn)稱OOP。面向?qū)ο蟮南嚓P(guān)概念:類對(duì)象接口面向?qū)ο笕筇卣鳎悍庋b、繼承和多態(tài)...TypeScript中類的定義與對(duì)象的使用定義類使用關(guān)鍵字class類中可以有屬性和方法類中的屬性和方法默認(rèn)都是public公有的屬性可以定義時(shí)初始化也可以通過(guò)構(gòu)造方法初始化class
Animal
{
private
name:
string
=
'小動(dòng)物';
//屬性,可以定義時(shí)初始化
private
age:
number;
//構(gòu)造方法給屬性做初始化
public
constructor(name:
string,
age:
number)
{
this.name
=
name;
this.age
=
age;
}
//獲取屬性name的值
public
getName()
{
return
this.name;
}
//設(shè)置屬性name的值
public
setName(name:
string)
{
this.name
=
name;
}
//age的get()和set()方法省略
//普通方法
public
info():
string
{
return
"Animal
info()
is
running...";
}}TypeScript中類的定義與對(duì)象的使用創(chuàng)建對(duì)象使用關(guān)鍵字newlet
animal
:Animal
=
new
Animal("小貓",2);console.log(animal.getName());//小貓TypeScript中類的定義與對(duì)象的使用繼承使用關(guān)鍵字extends子類繼承父類的屬性和方法子類可以重寫父類繼承下來(lái)的方法子類可以新增屬性和方法class
Cat
extends
Animal{
//增加子類的方法略
//重寫父類的info()方法
info():
string
{
return
"abc
cat
info";
}}TypeScript中類的定義與對(duì)象的使用多態(tài)多態(tài)是指由繼承而產(chǎn)生了相關(guān)的不同的類,對(duì)同一個(gè)方法可以有不同的響應(yīng)。多態(tài)是有前提的,在子類繼承父類并重寫父類的方法后,使用父類引用指向子類對(duì)象,訪問(wèn)的是子類經(jīng)過(guò)重寫的方法,從而呈現(xiàn)子類的狀態(tài)。let
animal2:Animal
=
new
Cat("大貓",3);console.log(());//訪問(wèn)的是Cat類經(jīng)過(guò)重寫的方法info()TypeScript中接口的聲明與使用接口是特殊的類,使用interface修飾,接口用來(lái)限定屬性和規(guī)定標(biāo)準(zhǔn)行為。聲明接口接口中的屬性不能初始化接口中的方法沒(méi)有方法體接口中的屬性和方法默認(rèn)都是public公有的interface
IAnimal
{
name:
string;
//定義接口的一個(gè)屬性,不能初始化
//sayHi是函數(shù)名,該函數(shù)沒(méi)有參數(shù),返回值類型為string
sayHi:
()
=>
string;
//定義接口的抽象方法,不能有方法體}TypeScript中接口的聲明與使用實(shí)現(xiàn)接口使用關(guān)鍵字implementsclass
Pig
implements
IAnimal
{
name:
string='小豬'
//可以初始化
sayHi():
string
{
//實(shí)現(xiàn)接口的方法
return
`Hi,${this.name}`;
}}TypeScript中接口的聲明與使用接口多態(tài)當(dāng)類實(shí)現(xiàn)了接口中的方法后,接口的引用指向?qū)崿F(xiàn)類對(duì)象,訪問(wèn)的是實(shí)現(xiàn)類的方法,從而呈現(xiàn)多種狀態(tài)。let
animal:
IAnimal
=
new
Pig();//接口的引用指向?qū)崿F(xiàn)類的對(duì)象console.log(animal.sayHi());
//Hi,小豬認(rèn)識(shí)ArkTS工程010203應(yīng)用程序包結(jié)構(gòu)相關(guān)的基本概念A(yù)rkTS工程目錄結(jié)構(gòu)ArkTS工程的配置文件04ArkTS工程的資源管理應(yīng)用程序包結(jié)構(gòu)相關(guān)的基本概念一個(gè)應(yīng)用包含一個(gè)或者多個(gè)Module;Module分為“Ability”和“Library”兩種類型;“Ability”類型的Module對(duì)應(yīng)于編譯后的HAP(HarmonyAbilityPackage);“Library”類型的Module對(duì)應(yīng)于HAR(HarmonyAbilityResources)包,即編譯后的.tgz文件。“Ability”類型的Module的HAP包可分為Entry和Feature兩種類型。Entry類型的HAP:是應(yīng)用的主模塊;Feature類型的HAP:是應(yīng)用的動(dòng)態(tài)特性模塊每個(gè)HarmonyOS應(yīng)用可以包含多個(gè).hap文件,一個(gè)應(yīng)用中的.hap文件合在一起稱為一個(gè)Bundle,而bundleName就是應(yīng)用的唯一標(biāo)識(shí)(請(qǐng)參見(jiàn)app.json5配置文件中的bundleName標(biāo)簽)ArkTS工程目錄結(jié)構(gòu)ArkTS工程的配置文件在基于Stage模型開(kāi)發(fā)的應(yīng)用項(xiàng)目代碼下,都存在app.json5及module.json5兩個(gè)配置文件。app.json5應(yīng)用的全局配置信息,包含應(yīng)用的包名、開(kāi)發(fā)廠商、版本號(hào)等基本信息。特定設(shè)備類型的配置信息。ArkTS工程的配置文件module.json5:Module的基本配置信息,例如Module名稱、類型、描述、支持的設(shè)備類型等基本信息。應(yīng)用組件信息,包含Ability組件和ExtensionAbility組件的描述信息。應(yīng)用訪問(wèn)系統(tǒng)或其他應(yīng)用受保護(hù)部分所需的權(quán)限信息。ArkTS工程的資源管理HarmonyOS資源分為兩類:應(yīng)用資源:借助資源文件能力,開(kāi)發(fā)者在應(yīng)用中自定義資源,自行管理這些資源在不同的設(shè)備或配置中的表現(xiàn)。系統(tǒng)資源:開(kāi)發(fā)者直接使用系統(tǒng)預(yù)置的資源定義(即分層參數(shù),同一資源ID在設(shè)備類型、深淺色等不同配置下有不同的取值)。ArkTS工程的資源管理應(yīng)用資源目錄應(yīng)用開(kāi)發(fā)中使用的各類資源文件,需要放入特定子目錄中存儲(chǔ)管理。在stage模型中,多模塊module共有的資源文件放到AppScope下的resources目錄。模塊獨(dú)有的資源可以放在該模塊的resources目錄下。resources目錄包括三大類目錄:base目錄限定詞目錄rawfile目錄ArkTS工程的資源管理創(chuàng)建應(yīng)用資源文件應(yīng)用已經(jīng)提供了一些資源文件,例如用來(lái)存放字符串的資源文件string.json,若還想創(chuàng)建其他的資源文件,例如布爾資源文件,則需要開(kāi)發(fā)者自己創(chuàng)建。在資源目錄的右鍵菜單選擇“New>XXXResourceFile”,即可創(chuàng)建對(duì)應(yīng)資源組目錄的資源文件。例如,在element目錄下可新建ElementResourceFile。如右圖在element目錄下創(chuàng)建一個(gè)布爾資源文件,一般文件名命名與根元素同名為boolean。ArkTS工程的資源管理訪問(wèn)應(yīng)用資源在工程中,通過(guò)"$r('')"的形式引用應(yīng)用資源。app代表是應(yīng)用內(nèi)resources目錄中定義的資源;type代表資源類型(或資源的存放位置),可以取“color”、“float”、“string”、“plural”、“media”;name代表資源命名,由開(kāi)發(fā)者定義資源時(shí)確定。例如:$r(‘a(chǎn)pp.string.string_hello’)表示引用字符串資源string_hello,具體是base還是相應(yīng)限定詞目錄下的視當(dāng)前設(shè)備的語(yǔ)言、設(shè)備類型等情況。另外:引用rawfile下資源時(shí)使用"$rawfile('filename')"的形式,filename需要表示為rawfile目錄下的文件相對(duì)路徑,文件名需要包含后綴,路徑開(kāi)頭不可以以"/"開(kāi)頭。例如$rawfile(‘test.png’)表示引用rawfile目錄下圖片。ArkTS工程的資源管理訪問(wèn)系統(tǒng)資源系統(tǒng)資源包含色彩、圓角、字體、間距、字符串及圖片等。通過(guò)使用系統(tǒng)資源,不同的開(kāi)發(fā)者可以開(kāi)發(fā)出具有相同視覺(jué)風(fēng)格的應(yīng)用。開(kāi)發(fā)者可以通過(guò)“$r('sys.type.resource_id')”的形式引用系統(tǒng)資源。sys代表是系統(tǒng)資源;type代表資源類型,可以取“color”、“float”、“string”、“media”;resource_id代表資源id。例如:$r('sys.color.ohos_id_color_emphasize')認(rèn)識(shí)ArkTS聲明式開(kāi)發(fā)010203ArkTS簡(jiǎn)介ArkUI框架ArkTS聲明式開(kāi)發(fā)范式的基本組成04ArkTS中的尺寸單位05ArkTS中組件的公共樣式ArkTS簡(jiǎn)介ArkTS是HarmonyOS優(yōu)選的主力應(yīng)用開(kāi)發(fā)語(yǔ)言。ArkTS基于TypeScript(簡(jiǎn)稱TS)語(yǔ)言擴(kuò)展而來(lái),是TS的超集。ArkTS繼承了TS的所有特征ArkTS在TS的基礎(chǔ)上擴(kuò)展了聲明式UI能力,當(dāng)前擴(kuò)展的聲明式UI能力包括如下特征:基本UI描述狀態(tài)管理動(dòng)態(tài)構(gòu)建UI元素渲染控制使用限制與擴(kuò)展ArkUI框架ArkUI是基于ArkTS的UI框架,基于ArkTS提供的擴(kuò)展語(yǔ)法,如下圖所示。ArkTS聲明式開(kāi)發(fā)范式的基本組成ArkTS聲明式開(kāi)發(fā)范式的基本組成:裝飾器自定義組件UI描述內(nèi)置組件屬性方法事件方法ArkTS中的尺寸單位ArkTS提供了4種像素單位,分別是px、vp、fp和lpx,框架采用vp為基準(zhǔn)數(shù)據(jù)單位。px:屏幕物理像素單位。vp:屏幕密度相關(guān)像素,根據(jù)屏幕像素密度轉(zhuǎn)換為屏幕物理像素fp:字體像素,與vp類似適用屏幕密度變化lpx:視窗邏輯像素單位在設(shè)置組件和容器寬高的字體大小使用固定值時(shí),使用number值不需要用單位,ArkTS會(huì)默認(rèn)給單位。例如:width(200)fontSize(50)ArkTS還可以使用百分比字符串來(lái)設(shè)置組件或布局的寬高。例如:width(‘100%’)表示寬度與父容器寬度相等。ArkTS中組件的公共樣式公共樣式:寬高(width/height/size)寬高比(aspectRatio)邊距(padding/margin)權(quán)重(layoutWeight)...示例:組件的寬高設(shè)置Column()
{
Text('你好').width(100).height(120)
.fontSize("50px")
//設(shè)置Text文字顯示組件的字體大小為50px
}.width('100%')
//設(shè)置Column的寬為100%,占滿屏幕寬度ArkTS中組件的公共樣式內(nèi)外邊距Text()…
.margin({bottom:30})//設(shè)置底部外邊距,底部距離下一個(gè)組件30Text()…//.padding(20)
//設(shè)置相同的邊距值
.padding({left:
20,
top:
30,
right:
40,
bottom:
50})//設(shè)置不同的邊距值示例:設(shè)置組件的內(nèi)外邊距Row與Column組件的使用010203容器組件概述Column和Row組件介紹線性布局的權(quán)重設(shè)置容器組件概述容器組件是一種比較特殊的組件,它可以包含其他的組件,而且按照一定的規(guī)律布局。容器組件除了放置基礎(chǔ)組件外,也可以放置容器組件,通過(guò)多層布局的嵌套,可以布局出更豐富的頁(yè)面。ArkTS為我們提供了豐富的容器組件來(lái)布局頁(yè)面,例如使用Column和Row容器組件實(shí)現(xiàn)如下效果。Column和Row組件介紹線性布局容器概念Column和Row組件是ArkTS提供用來(lái)實(shí)現(xiàn)線性布局的容器組件。線性布局表示按照垂直方向或者水平方向排列子組件的容器。Column表示沿垂直方向布局的容器。Row表示沿水平方向布局的容器。Column和Row組件介紹主軸與交叉軸的概念在線性布局容器中,存在兩根軸,分別是主軸和交叉軸,這兩個(gè)軸始終是相互垂直的。不同的容器中主軸的方向不一樣的。主軸:在Column容器中的子組件是按照從上到下的垂直方向布局的,其主軸的方向是垂直方向;在Row容器中的組件是按照從左到右的水平方向布局的,其主軸的方向是水平方向。Column和Row組件介紹交叉軸:與主軸垂直相交的軸線,如果主軸是垂直方向,則交叉軸就是水平方向;如果主軸是水平方向,則交叉軸是垂直方向。Column和Row組件介紹主軸與交叉軸的對(duì)齊格式Column和Row容器默認(rèn)都在主軸和交叉軸上居中顯示子組件。同時(shí),他們也提供屬性justifyContent和alignItems用來(lái)設(shè)置子組件在主軸和交叉軸的對(duì)齊格式。主軸方向的對(duì)齊格式(justifyContent)子組件在主軸方向上的對(duì)齊使用justifyContent屬性來(lái)設(shè)置,其參數(shù)類型是FlexAlign。FlexAlign定義了以下幾種類型:StartCenterEndSpaceBetweenSpaceAroundSpaceEvenlyColumn和Row組件介紹Column在主軸上的對(duì)齊格式:Row在主軸上的對(duì)齊格式:Column和Row組件介紹交叉軸方向的對(duì)齊(alignItems)子組件在交叉軸方向上的對(duì)齊方式使用alignItems屬性來(lái)設(shè)置。Column容器的主軸是垂直方向,交叉軸是水平方向,其參數(shù)類型為HorizontalAlign(水平對(duì)齊),HorizontalAlign定義了以下幾種類型:Start:設(shè)置子組件在水平方向上按照起始端對(duì)齊。Center(默認(rèn)值):設(shè)置子組件在水平方向上居中對(duì)齊。End:設(shè)置子組件在水平方向上按照末端對(duì)齊。Column和Row組件介紹Row容器的主軸是水平方向,交叉軸是垂直方向,其參數(shù)類型為VerticalAlign(垂直對(duì)齊),VerticalAlign定義了以下幾種類型:Top:設(shè)置子組件在垂直方向上居頂部對(duì)齊。Center(默認(rèn)值):設(shè)置子組件在豎直方向上居中對(duì)齊。Bottom:設(shè)置子組件在豎直方向上居底部對(duì)齊。線性布局的權(quán)重設(shè)置權(quán)重屬性表示一行或一列中的尺寸按照權(quán)重比進(jìn)行分配,僅適用于線性布局組件下的子組件,如果同時(shí)設(shè)置了某一個(gè)方向上的尺寸和權(quán)重,此時(shí)子組件設(shè)置的尺寸不起作用。基礎(chǔ)組件1組件概述組件(Component)是界面搭建與顯示的最小單位,
HarmonyOSArkUI聲明式開(kāi)發(fā)范式為開(kāi)發(fā)者提供了豐富多樣的UI組件。組件根據(jù)功能可以分為以下五大類:基礎(chǔ)組件、容器組件、媒體組件、繪制組件、畫布組件。其中基礎(chǔ)組件是視圖層的基本組成單元,包括Text、Image、TextInput、Button、LoadingProgress等。010203文本組件Text圖片組件Image空白填充組件Blank04分割線組件Divider文本組件TextText組件用于顯示文本信息。常用的屬性有:fontSize:設(shè)置字體大小fontColor:設(shè)置字體顏色textAlign:設(shè)置文本對(duì)齊格式fontWeight:設(shè)置字體權(quán)重fontStyle:設(shè)置字體樣式decoration:設(shè)置文本裝飾線maxLines:設(shè)置文本最大行數(shù)textOverFlow:設(shè)置文本超長(zhǎng)時(shí)的顯示方式文本組件TextText('Hello,
HarmonyOS;
Hi
ArkUI')
.fontSize(20)
//大小
.fontColor('#ff0000')
//顏色
.textAlign(TextAlign.Center)
//文本的對(duì)齊方式(Start/Center/End)
.fontWeight(FontWeight.Bold)
//字重
.fontStyle(FontStyle.Italic)
//樣式(正常:Normal
斜體:Italic)
//給文本添加裝飾線,Unerline為下劃線
.decoration({type:
TextDecorationType.Underline,
color:
Color.Black})
.maxLines(1)
//設(shè)置行數(shù)為1時(shí)可與下面的截?cái)喾绞脚浜鲜褂?/p>
.textOverflow({overflow:
TextOverflow.Ellipsis})//截?cái)喾绞綀D片組件ImageImage組件用來(lái)渲染展示圖片,只需要給Image組件設(shè)置圖片地址、寬和高,圖片就能顯示出來(lái)。示例代碼如下。Image($r("app.media.icon"))
.width(100)
.height(100)圖片地址可以是本地圖片也可以是網(wǎng)絡(luò)圖片。引用本地圖片資源時(shí),建議使用$r方式來(lái)管理需全局使用的圖片資源。支持的圖片格式包括png、jpg、bmp、svg和gif。圖片組件Image圖片縮放處理使用objectFit屬性設(shè)置圖片的縮放類型,objectFit的參數(shù)類型為ImageFit。ImageFit.Cover(默認(rèn)值):保持寬高比進(jìn)行縮小或者放大,使得圖片兩邊都大于或等于顯示邊界;ImageFit.Fill:不保持寬高比進(jìn)行放大縮小,使得圖片充滿顯示邊界,可以看到圖片為了適應(yīng)屏幕,改變了寬高比;ImageFit.Contain:保持寬高比進(jìn)行縮小或者放大,使得圖片完全顯示在顯示邊界內(nèi);ImageFit.None:保持原有尺寸顯示;ImageFit.ScaleDown:保持寬高比顯示,圖片縮小或者保持不變。圖片組件Image原圖ImageFit.CoverImageFit.FillImageFit.ContainImageFit.NoneImageFit.ScaleDown空白填充組件BlankBlank表示空白填充組件,在線性布局容器組件內(nèi)用來(lái)填充組件在主軸方向上的剩余尺寸。例如:在下圖中,Blank在Row方向上的使用,除了子組件的本身寬度尺寸外,剩余尺寸用Blank占滿,子組件可以很容易實(shí)現(xiàn)靠左或靠右擺放。分隔線組件Divider在UI開(kāi)發(fā)中經(jīng)常用到的分割線,可以用組件Divider實(shí)現(xiàn)。使用的示例代碼如下。Divider()
//無(wú)參
.vertical(true)
//分割線的方向,默認(rèn)是false水平,true代表垂直方向
.color(Color.Red)
//分割線的顏色
.strokeWidth(1)
//分割線的線寬
.lineCap(LineCapStyle.Round)//分割線的樣式開(kāi)發(fā)數(shù)據(jù)展示頁(yè)010203彈性布局Flex層疊布局容器Stack進(jìn)度條組件Progress04滑動(dòng)條組件Slider彈性布局Flex彈性布局Flex可以靈活的實(shí)現(xiàn)線性布局Row和Column的設(shè)置效果,F(xiàn)lex的排列方向和對(duì)齊格式是在參數(shù)中設(shè)置的。參數(shù)direction的值決定Flex的排列方向。彈性布局Flex參數(shù)justfyContent的值決定主軸的對(duì)齊格式。參數(shù)alignItems的值決定交叉軸的對(duì)齊格式。層疊布局容器Stack層疊布局容器組件Stack,是把子組件按照設(shè)置的對(duì)齊格式順序依次堆疊,后一個(gè)子組件覆蓋在前一個(gè)子組件上邊。子組件的對(duì)齊方式使用alignContent參數(shù)來(lái)設(shè)置。進(jìn)度條組件ProgressProgress進(jìn)度條,用于顯示內(nèi)容加載或操作處理等進(jìn)度。不同類型的進(jìn)度條Progress參數(shù):value:指定當(dāng)前進(jìn)度值(必填)total:指定進(jìn)度總長(zhǎng),默認(rèn)值100.(選填)type:指定進(jìn)度條類型,默認(rèn)值ProgressType.Linear(選填)Progress常用屬性color:進(jìn)度條的顏色,默認(rèn)為藍(lán)色style:進(jìn)度條的樣式,樣式內(nèi)的可選設(shè)置有strokeWidth:設(shè)置進(jìn)度條寬度scaleCount:設(shè)置環(huán)形進(jìn)度條總刻度scaleWidth:設(shè)置環(huán)形進(jìn)度條刻度粗細(xì)value:當(dāng)前進(jìn)度,會(huì)覆蓋參數(shù)的當(dāng)前進(jìn)度進(jìn)度條組件ProgressProgress({
value:
85,
//參數(shù)1:必選,當(dāng)前進(jìn)度
total:100,
//參數(shù)2:可選,最大進(jìn)度,默認(rèn)100
type:
ProgressType.ScaleRing
//參數(shù)3:可選,進(jìn)度條類型})
.size({width:
80,
height:
80})
.color(Color.Pink)
//屬性1:進(jìn)度條的顏色,默認(rèn)為藍(lán)色
.style({
//屬性2:設(shè)置進(jìn)度條的樣式
strokeWidth:20,
//strokeWidth:設(shè)置進(jìn)度條寬度
scaleCount:100,
//scaleCount:設(shè)置環(huán)形進(jìn)度條總刻度數(shù)
scaleWidth:10
//scaleWidth:設(shè)置環(huán)形進(jìn)度條刻度粗細(xì)
})
.value(22)
//屬性3:當(dāng)前進(jìn)度,會(huì)覆蓋參數(shù)的當(dāng)前進(jìn)度滑動(dòng)條組件Slider滑動(dòng)條組件Slider,用來(lái)快速調(diào)節(jié)音量、亮度等。Slider組件默認(rèn)寬度為父容器寬度的100%。Slider常用的參數(shù)說(shuō)明如下:Slider(value:{value?:
number,
//當(dāng)前進(jìn)度值,默認(rèn)值0
min?:
number,
//設(shè)置最小值,默認(rèn)值0max?:
number,
//設(shè)置最大值,默認(rèn)值100step?:
number,
//設(shè)置Slider滑動(dòng)跳動(dòng)值,默認(rèn)值1style?:
SliderStyle
//設(shè)置Slider的滑塊樣式,默認(rèn)值Outset})滑動(dòng)條組件SliderSliderStyle的取值有兩種SliderStyle.OutSet:滑塊在滑軌上SliderStyle.InSet:滑塊在滑軌內(nèi)Slider(){...
}
.blockColor(Color.Red)//設(shè)置滑塊的顏色
.selectedColor(Color.Green)//設(shè)置滑軌的已滑動(dòng)顏色
.showSteps(true)//默認(rèn)值false,設(shè)置當(dāng)前是否顯示步長(zhǎng)刻度值
.showTips(true)//默認(rèn)值false,設(shè)置滑動(dòng)時(shí)是否顯示氣泡提示百分比}SliderStyle常用的屬性滑動(dòng)條組件SliderSlider滑動(dòng)時(shí)觸發(fā)onChange的事件回調(diào),value為當(dāng)前進(jìn)度值,mode為拖動(dòng)狀態(tài)。其中mode有4種:SliderChangeMode.Begin:開(kāi)始拖動(dòng)滑塊。SliderChangeMode.Moving:正在拖動(dòng)滑塊過(guò)程中。SliderChangeMode.End:結(jié)束拖動(dòng)滑塊。SliderChangeMode.Click:點(diǎn)擊滑動(dòng)條使滑塊位置移動(dòng)。Slider(){...
}.onChange((value:
number,
mode:
SliderChangeMode)
=>
{
//todo
})彈性布局與層疊布局彈性布局Flex彈性布局Flex可以靈活的實(shí)現(xiàn)線性布局Row和Column的設(shè)置效果,F(xiàn)lex的排列方向和對(duì)齊格式是在參數(shù)中設(shè)置的。參數(shù)direction的值決定Flex的排列方向。彈性布局Flex參數(shù)justifyContent的值決定主軸的對(duì)齊格式。參數(shù)alignItems的值決定交叉軸的對(duì)齊格式。彈性布局Flex-使用示例@Entry@Componentstruct
FlexExample
{
build()
{
Flex({
direction:
FlexDirection.Row,
justifyContent:
FlexAlign.End,
alignItems:
ItemAlign.Center
})
{
Text('文本1')
.width('30%')
.height(50)
.backgroundColor(0xF5DEB3)
.textAlign(TextAlign.Center)
Text('文本2')
.width('30%')
.height(70)
.backgroundColor(0xD2B48C)
.textAlign(TextAlign.Center)
Text('文本3')
.width('30%')
.height('100%')
.backgroundColor(0xF5DEB3)
.textAlign(TextAlign.Center)
}.width('100%').height(120).padding(10).backgroundColor(0xAFEEEE)
}}層疊布局容器Stack層疊布局容器組件Stack,是把子組件按照設(shè)置的對(duì)齊格式順序依次堆疊,后一個(gè)子組件覆蓋在前一個(gè)子組件上邊。子組件的對(duì)齊方式使用alignContent參數(shù)來(lái)設(shè)置。層疊布局容器Stack-使用示例@Entry@Componentstruct
StackExample
{
build()
{
Stack({
alignContent:
Alignment.Bottom
})
{
Text('第一個(gè)子組件').width('90%').height('100%').backgroundColor('#d2cab3').align(Alignment.Top)
Text('第二個(gè)子組件').width('70%').height('60%').backgroundColor('#c1cbac').align(Alignment.Top)
Text('第三個(gè)子組件').width('50%').height('30%').backgroundColor('#e0e3d8').align(Alignment.Top)
}.width('100%').height(150).margin({
top:
5
})
}}進(jìn)度條和滑動(dòng)條進(jìn)度條組件ProgressProgress進(jìn)度條,用于顯示內(nèi)容加載進(jìn)度或操作處理進(jìn)度等。不同類型的進(jìn)度條Progress參數(shù):value:指定當(dāng)前進(jìn)度值(必填)total:指定進(jìn)度總長(zhǎng),默認(rèn)值100.(選填)type:指定進(jìn)度條類型,默認(rèn)值ProgressType.Linear(選填)Progress常用屬性color:進(jìn)度條的顏色,默認(rèn)為藍(lán)色style:進(jìn)度條的樣式,樣式內(nèi)的可選設(shè)置有strokeWidth:設(shè)置進(jìn)度條寬度scaleCount:設(shè)置環(huán)形進(jìn)度條總刻度scaleWidth:設(shè)置環(huán)形進(jìn)度條刻度粗細(xì)value:當(dāng)前進(jìn)度,會(huì)覆蓋參數(shù)的當(dāng)前進(jìn)度進(jìn)度條組件Progress-使用示例Progress({
value:
85,
//參數(shù)1:必選,當(dāng)前進(jìn)度
total:100,
//參數(shù)2:可選,最大進(jìn)度,默認(rèn)100
type:
ProgressType.ScaleRing
//參數(shù)3:可選,進(jìn)度條類型})
.size({width:
80,
height:
80})
.color(Color.Pink)
//屬性1:進(jìn)度條的顏色,默認(rèn)為藍(lán)色
.style({
//屬性2:設(shè)置進(jìn)度條的樣式
strokeWidth:20,
//strokeWidth:設(shè)置進(jìn)度條寬度
scaleCount:100,
//scaleCount:設(shè)置環(huán)形進(jìn)度條總刻度數(shù)
scaleWidth:10
//scaleWidth:設(shè)置環(huán)形進(jìn)度條刻度粗細(xì)
})
.value(22)
//屬性3:當(dāng)前進(jìn)度,會(huì)覆蓋參數(shù)的當(dāng)前進(jìn)度滑動(dòng)條組件Slider滑動(dòng)條組件Slider,用來(lái)快速調(diào)節(jié)音量、亮度等。Slider組件默認(rèn)寬度為父容器寬度的100%。Slider常用的參數(shù):Slider(value:{value?:
number,
//當(dāng)前進(jìn)度值,默認(rèn)值0
min?:
number,
//設(shè)置最小值,默認(rèn)值0max?:
number,
//設(shè)置最大值,默認(rèn)值100step?:
number,
//設(shè)置Slider滑動(dòng)跳動(dòng)值,默認(rèn)值1style?:
SliderStyle
//設(shè)置Slider的滑塊樣式,默認(rèn)值OutSet})滑動(dòng)條組件SliderSliderStyle的取值有兩種SliderStyle.OutSet:滑塊在滑軌上SliderStyle.InSet:滑塊在滑軌內(nèi)Slider(){...
}
.blockColor(Color.Red)//設(shè)置滑塊的顏色
.selectedColor(Color.Green)//設(shè)置滑軌的已滑動(dòng)顏色
.showSteps(true)//默認(rèn)值false,設(shè)置當(dāng)前是否顯示步長(zhǎng)刻度值
.showTips(true)//默認(rèn)值false,設(shè)置滑動(dòng)時(shí)是否顯示氣泡提示百分比}Slider常用的屬性滑動(dòng)條組件SliderSlider滑動(dòng)時(shí)觸發(fā)onChange的事件回調(diào),在回調(diào)方法內(nèi)箭頭函數(shù)的參數(shù)value為當(dāng)前進(jìn)度值,mode為拖動(dòng)狀態(tài)。其中mode有4種:SliderChangeMode.Begin:開(kāi)始拖動(dòng)滑塊。SliderChangeMode.Moving:正在拖動(dòng)滑塊過(guò)程中。SliderChangeMode.End:結(jié)束拖動(dòng)滑塊。SliderChangeMode.Click:點(diǎn)擊滑動(dòng)條使滑塊位置移動(dòng)。Slider(){...
}.onChange((value:
number,
mode:
SliderChangeMode)
=>
{
//todo
})滑動(dòng)組件Slider-使用示例@Entry@Componentstruct
SliderExample
{
@State
inSetValue:
number
=
40
build()
{
Column({
space:
8
})
{
Text('滑塊在導(dǎo)軌內(nèi)').fontSize(9).fontColor(0xCCCCCC).width('90%').margin(15)
Row()
{
Slider({
value:
this.inSetValue,
step:
10,
style:
SliderStyle.InSet
})
.blockColor('#191970').trackColor('#ADD8E6').selectedColor('#4169E1')
.showSteps(true)
.onChange((value:
number,
mode:
SliderChangeMode)
=>
{
this.inSetValue
=
value
console.info('value:'
+
value
+
'mode:'
+
mode.toString())
})
Text(this.inSetValue+"").fontSize(12)
}
.width('80%')
}.width('100%')
}}開(kāi)發(fā)登錄頁(yè)010203輸入框組件Input按鈕組件Button開(kāi)關(guān)組件Toggle04文本提示框promptAction輸入框組件TextInputTextInput組件用于輸入單行文本,響應(yīng)輸入事件。TextInput的使用也非常廣泛,例如在登錄頁(yè)中的賬號(hào)輸入和密碼輸入。TextInput組件支持文本樣式設(shè)置TextInput()
.fontColor(Color.Blue)
.fontSize(20)
.fontStyle(FontStyle.Italic)
.fontWeight(FontWeight.Bold)
.fontFamily('Arial')輸入框組件TextInput設(shè)置輸入提示文本我們平常使用輸入框時(shí)常??吹捷斎肟蛏蠒?huì)有提示文字,例如登錄賬號(hào)時(shí)會(huì)有“請(qǐng)輸入賬號(hào)”這樣的文本提示,當(dāng)用戶輸入內(nèi)容后,提示文本就消失了。使用placeholder設(shè)置提示文本使用placeholderColor和placeholderFont分別設(shè)置提示文本的顏色和樣式。TextInput({
placeholder:
'請(qǐng)輸入帳號(hào)'
})
.placeholderColor(‘#999999')
.placeholderFont({
size:
20,
weight:
FontWeight.Medium,
family:
'cursive',
style:
FontStyle.Italic
})輸入框組件TextInput設(shè)置輸入類型可以使用type屬性來(lái)設(shè)置輸入框類型。例如密碼輸入框,一般輸入密碼的時(shí)候,為了用戶密碼安全,內(nèi)容會(huì)顯示為“”。這種情況就可以設(shè)置type屬性值為InputType.Password實(shí)現(xiàn),如下面示例所示。TextInput({
placeholder:
'請(qǐng)輸入密碼'
})
.type(InputType.Password)輸入框組件TextInput輸入類型InputType枚舉值:Normal:基本輸入模式。支持輸入數(shù)字、字母、下劃線、空格、特殊字符。Password:密碼輸入模式。Email:e-mail地址輸入模式。Number:純數(shù)字輸入模式。輸入框組件TextInput獲取輸入文本在onChange事件回調(diào)方法中,獲取輸入框的輸入文本。如下面示例所示。
TextInput({
placeholder:
'請(qǐng)輸入賬號(hào)'
})
.onChange((value:
string)
=>
{
this.text
=
value//this.text為@State修飾的狀態(tài)變量
})按鈕組件ButtonButton組件主要用來(lái)響應(yīng)點(diǎn)擊操作,可以包含子組件。Button使用示例Button('登錄',
{
type:
ButtonType.Capsule,
stateEffect:
true
})
.width('90%')
.onClick(()
=>
{
//處理點(diǎn)擊事件邏輯
}))示例中的代碼,type用于定義按鈕樣式,ButtonType.Capsule表示膠囊形按鈕;stateEffect用于設(shè)置按鈕按下時(shí)是否開(kāi)啟切換效果,當(dāng)狀態(tài)置為false時(shí),點(diǎn)擊效果關(guān)閉,默認(rèn)值為true。并且給Button綁定onClick事件,每當(dāng)用戶點(diǎn)擊Button的時(shí)候,就會(huì)回調(diào)執(zhí)行onClick方法,調(diào)用里面的邏輯代碼。按鈕組件Button按鈕樣式ButtonType枚舉值Capsule:膠囊型按鈕(圓角默認(rèn)為高度的一半)。Circle:圓形按鈕。Normal:普通按鈕(默認(rèn)不帶圓角)。按鈕組件Button包含子組件Button組件可以包含子組件,例如在Button組件包含了一個(gè)Image組件。Button({
type:
ButtonType.Circle,
stateEffect:
true
})
{
Image($r('app.media.icon_delete'))
.width(30)
.height(30)}.width(55).height(55).backgroundColor('#317aff')開(kāi)關(guān)組件ToggleToggle組件表示開(kāi)關(guān),開(kāi)關(guān)狀態(tài)的初始化用isOn參數(shù)進(jìn)行設(shè)置;使用type設(shè)置開(kāi)關(guān)樣式,開(kāi)關(guān)狀態(tài)切換時(shí)觸發(fā)onChange事件回調(diào)方法。Toggle({
isOn:true,
//設(shè)置開(kāi)關(guān)狀態(tài)組件初始化狀態(tài)為開(kāi)
type:
ToggleType.Switch})//設(shè)置組件為開(kāi)關(guān)樣式
.selectedColor("#ffa6c88c")//設(shè)置組件打開(kāi)狀態(tài)的背景顏色
.switchPointColor(Color.Red)//設(shè)置
type類型為
Switch時(shí)的圓形滑塊顏色
.onChange((isOn)
=>
{//事件回調(diào),isOn為開(kāi)與關(guān)的狀態(tài)值
console.log(
"開(kāi)關(guān)狀態(tài):"
+
isOn)
})Toggle的type樣式:ToggleType.Switch為開(kāi)關(guān)樣式;ToggleType.Checkbox為單選框樣式;ToggleType.Button為按鈕樣式,可以在Toggle中加入子組件。文本提示框promptActionpromptAction是在@mptAction模塊里提供的,使用時(shí)需要導(dǎo)入@mptAction模塊,用promptAction.showToast()提示信息。import
promptAction
from
'@mptAction';
//導(dǎo)入文本提示框模塊…
promptAction.showToast({
message:
"消息",
//顯示文本,必填項(xiàng)
duration:
2000,
//顯示時(shí)長(zhǎng),可選項(xiàng),單位毫秒,范圍
[1500,
10000],默1500
bottom:
1000
//Toast的顯示位置距離底部的間距,可選項(xiàng)
})基礎(chǔ)組件2010203輸入框組件Input按鈕組件Button開(kāi)關(guān)組件Toggle輸入框組件TextInputTextInput組件用于輸入單行文本,響應(yīng)輸入事件。TextInput的使用也非常廣泛,例如在登錄頁(yè)中的賬號(hào)輸入和密碼輸入。TextInput組件支持文本樣式設(shè)置TextInput()
.fontColor(Color.Blue)
.fontSize(20)
.fontStyle(FontStyle.Italic)
.fontWeight(FontWeight.Bold)
.fontFamily('Arial')輸入框組件TextInput設(shè)置輸入提示文本我們平常使用輸入框時(shí)常??吹捷斎肟蛏蠒?huì)有提示文字,例如登錄賬號(hào)時(shí)會(huì)有“請(qǐng)輸入賬號(hào)”這樣的文本提示,當(dāng)用戶輸入內(nèi)容后,提示文本就消失了。使用placeholder設(shè)置提示文本使用placeholderColor和placeholderFont分別設(shè)置提示文本的顏色和樣式。TextInput({
placeholder:
'請(qǐng)輸入帳號(hào)'
})
.placeholderColor(‘#999999')
.placeholderFont({
size:
20,
weight:
FontWeight.Medium,
family:
'cursive',
style:
FontStyle.Italic
})輸入框組件TextInput設(shè)置輸入類型可以使用type屬性來(lái)設(shè)置輸入框類型。例如密碼輸入框,一般輸入密碼的時(shí)候,為了用戶密碼安全,內(nèi)容會(huì)顯示為“”。這種情況就可以設(shè)置type屬性值為InputTyp
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年貨運(yùn)代理服務(wù)與貨款代收合同
- 2025年度知識(shí)產(chǎn)權(quán)訴訟居間代理提成保證合同3篇
- 簡(jiǎn)單水粉風(fēng)景畫課程設(shè)計(jì)
- 2025年度電影導(dǎo)演聘用及電影票務(wù)分成合同3篇
- 溫度控制plc課程設(shè)計(jì)
- 2024年綠色殯葬服務(wù)草皮采購(gòu)合同
- 2025年度教育培訓(xùn)價(jià)格保密協(xié)議范本3篇
- 2024年藝人 management 合同:演員經(jīng)紀(jì)與包裝
- 成都藝術(shù)職業(yè)大學(xué)《數(shù)據(jù)庫(kù)實(shí)驗(yàn)》2023-2024學(xué)年第一學(xué)期期末試卷
- 2025版市政綠化工程造價(jià)咨詢合同3篇
- (八省聯(lián)考)2025年高考綜合改革適應(yīng)性演練 語(yǔ)文試卷(含答案解析)
- GB/T 45002-2024水泥膠砂保水率測(cè)定方法
- ISO 56001-2024《創(chuàng)新管理體系-要求》專業(yè)解讀與應(yīng)用實(shí)踐指導(dǎo)材料之1:0 引言(雷澤佳編制-2025B0)
- 2024版環(huán)衛(wèi)清潔班車租賃服務(wù)協(xié)議3篇
- 生產(chǎn)安全事故事件管理知識(shí)培訓(xùn)課件
- 項(xiàng)目施工單位與當(dāng)?shù)卣按迕竦膮f(xié)調(diào)措施
- 藥劑科工作人員的專業(yè)提升計(jì)劃
- 2024-2025學(xué)年度第一學(xué)期二年級(jí)語(yǔ)文寒假作業(yè)第二十一天
- 貸款用設(shè)備購(gòu)銷合同范例
- 公務(wù)員行測(cè)真題題庫(kù)及答案
- 2025支部會(huì)議記錄范文
評(píng)論
0/150
提交評(píng)論