在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

HarmonyOS自定義列表組件封裝

OpenHarmony技術(shù)社區(qū) ? 來源:OpenHarmony技術(shù)社區(qū) ? 作者:韋海 ? 2022-04-26 10:57 ? 次閱讀

根據(jù)OpenHarmony官網(wǎng)組件,結(jié)合相關(guān)技術(shù),嘗試列表組件的封裝,提高開發(fā)的效率。

效果展示:

f565c3a8-c480-11ec-bce3-dac502259ad0.gif ?

實(shí)現(xiàn)步驟

①封裝組件代碼

hml 代碼:

<divclass="container{{start?'background':''}}">

<divclass="underline">

<divclass="list-left">
<div>
<textclass="title">{{title}}text>
div>

<divclass="list-des"
if="{{subheading}}">
<textclass="list">
<span>{{subheading}}span>
text>
div>
div>

<divclass="list-right">
<switchclass="switch-list"
if="{{whether}}"
@change="switchHandle">
switch>

<imageelse@click="launch()"class="list-icon"src="../images/right.png">
image>
div>
div>
div>

css 代碼:

.container{
justify-content:center;
align-items:center;
padding-left:48px;
padding-right:35px;
overscroll-effect:spring;
}

.background:active{
background-color:#f6f6f6;
}

.underline{
border-bottom:1pxsolid#ccc;
}

/*標(biāo)題樣式代碼*/
.list-left{
flex:1;
flex-direction:column;
justify-content:center;
}

.title{
font-family:FZLTHJW--GB1-0;
font-size:32px;
color:rgba(0,0,0,0.9);
letter-spacing:0;
font-weight:400;
height:70px;
}

.list-des{
width:530px;
flex-wrap:wrap;
margin-bottom:10px;
}

.list{
font-family:HarmonyOS_Sans;
font-size:28px;
color:rgba(0,0,0,0.6);
letter-spacing:0;
line-height:35px;
font-weight:400;
padding-bottom:2px;
}

/*switch開關(guān)樣式代碼*/
.list-right{
justify-content:flex-end;
width:115px;
min-height:100px;
align-items:center;
}

.switch-list{
width:115px;
height:120px;
}

.list-icon{
width:14px;
height:26px;
right:20px;
}

js 代碼:

exportdefault{
props:{
//數(shù)據(jù)綁定
title:{
default:''
},
//數(shù)據(jù)綁定
subheading:{
default:''
},

//true是switch開關(guān),false是圖標(biāo)
whether:{
default:true,
type:Boolean
},

//判斷是不是switch開關(guān)列表,不是就加點(diǎn)擊陰影事件
start:{
default:true,
type:Boolean
},

},

computed:{
//判斷是不是switch開關(guān)列表,不是就加點(diǎn)擊陰影事件
start(){
return!this.whether
},
},

/**
*切換開關(guān)
*/
switchHandle({checked:checkedValue}){
this.$emit('switchHandle',checkedValue);
this.checkStatus=checkedValue;
},

};

②引入組件代碼,實(shí)現(xiàn)列表功能

hml 代碼:

<elementname="list-page"src="../../common/listitem/listitem.hml">element>
<divclass="container">
<list-pagewhether="{{true}}"
@switch-handle="showDialog"
title="標(biāo)題1"
subheading="副文本">
list-page>
<list-pagewhether="{{true}}"
title="標(biāo)題2">
list-page>

<list-pagewhether="{{false}}"
title="標(biāo)題3">
list-page>

<list-pagewhether="{{false}}"
title="標(biāo)題4"
subheading="副文本">
list-page>

div>

css 代碼:

.container{
flex-direction:column;
color:#fff;
background-color:#fff;
overscroll-effect:spring;
}

效果圖為:

f577f456-c480-11ec-bce3-dac502259ad0.png③在標(biāo)題 1 加彈窗

hml 代碼:


<dialogid="dataRoamDialog"class="dialog-main">
<divclass="dialog-divroaming">
<textclass="text">什么彈窗text>
<divclass="inner-txt">
<textclass="txtdistance">彈窗text>
div>

<divclass="inner-btn">
<buttontype="capsule"
value="確定"
onclick="setList"
class="btn-txt">
button>
<divclass="btn-l">div>
<buttontype="capsule"
value="取消"
onclick="setList"
class="btn-txt">
button>
div>
div>
dialog>

css 代碼:

/*彈窗樣式*/
.dialog-main{
width:95%;
}

.dialog-div{
flex-direction:column;
align-items:flex-start;
}

.roaming{
height:340px;
}

.text{
font-family:HarmonyOS_Sans_Medium;
font-size:36px;
color:rgba(0,0,0,0.9);
letter-spacing:0;
line-height:38px;
font-weight:bold;
height:112px;
padding:40px0040px;
}

.inner-txt{
width:90%;
}

.txt{
font-family:HarmonyOS_Sans;
font-size:32px;
color:rgba(0,0,0,0.9);
letter-spacing:0;
line-height:38px;
font-weight:400;
flex:1;
height:75px;
justify-content:space-between;
font-family:PingFangSC-Regular;
}

.distance{
padding-left:40px;
margin-top:20px;
}

.inner-btn{
width:100%;
height:120px;
line-height:80px;
justify-content:center;
align-items:center;
margin:10px20px020px;
}

.btn-txt{
width:230px;
height:80px;
font-size:32px;
text-color:#1e90ff;
background-color:#fff;
text-align:left;
align-items:center;
flex:1;
text-align:center;
}

.btn-l{
width:2px;
height:50px;
background-color:#ccc;
margin:010px;
}

js 代碼:

exportdefault{
/**
*標(biāo)題1彈窗開啟
*/
showDialog(){
this.$element('dataRoamDialog').show();
},

/**
*標(biāo)題1彈窗取消
*/
setList(){
this.$element('dataRoamDialog').close();
},
}

效果圖:

f586f410-c480-11ec-bce3-dac502259ad0.png ?

總結(jié)

以上是所有的代碼,寫這個(gè)不難。主要用到了數(shù)據(jù)綁定跟三元運(yùn)算和彈窗組件。相當(dāng)于學(xué)習(xí)了OpenHarmony的開發(fā),自己嘗試封裝,讓自己更加了解OpenHarmony開發(fā)。歡迎各位開發(fā)者一起討論與研究,本次分享希望對(duì)大家的學(xué)習(xí)有所幫助。

審核編輯 :李倩

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4891

    瀏覽量

    70348
  • 封裝組件
    +關(guān)注

    關(guān)注

    0

    文章

    2

    瀏覽量

    5249
  • HarmonyOS
    +關(guān)注

    關(guān)注

    80

    文章

    2085

    瀏覽量

    32323

原文標(biāo)題:HarmonyOS自定義列表組件封裝

文章出處:【微信號(hào):gh_834c4b3d87fe,微信公眾號(hào):OpenHarmony技術(shù)社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    KiCad 中的自定義規(guī)則(KiCon 演講)

    “ ?Seth Hillbrand 在 KiCon US 2025 上為大家介紹了 KiCad 的規(guī)則系統(tǒng),并詳細(xì)講解了自定義規(guī)則的設(shè)計(jì)與實(shí)例。? ” ? 演講主要圍繞 加強(qiáng) KiCad 中的自定義
    的頭像 發(fā)表于 06-16 11:17 ?112次閱讀
    KiCad 中的<b class='flag-5'>自定義</b>規(guī)則(KiCon 演講)

    HarmonyOS實(shí)戰(zhàn):自定義時(shí)間選擇器

    前言 最近在日常鴻蒙開發(fā)過程中,經(jīng)常會(huì)使用一些時(shí)間選擇器,鴻蒙官方提供的時(shí)間選擇器滿足不了需求,所以自己動(dòng)手自定義一些經(jīng)常會(huì)使用到的時(shí)間選擇器,希望能幫到你,建議點(diǎn)贊收藏! 實(shí)現(xiàn)效果 需求分析 默認(rèn)
    的頭像 發(fā)表于 06-09 15:51 ?103次閱讀
    <b class='flag-5'>HarmonyOS</b>實(shí)戰(zhàn):<b class='flag-5'>自定義</b>時(shí)間選擇器

    HarmonyOS應(yīng)用自定義鍵盤解決方案

    自定義鍵盤是一種替換系統(tǒng)默認(rèn)鍵盤的解決方案,可實(shí)現(xiàn)鍵盤個(gè)性化交互。允許用戶結(jié)合業(yè)務(wù)需求與操作習(xí)慣,對(duì)按鍵布局進(jìn)行可視化重構(gòu)、設(shè)置多功能組合鍵位,使輸入更加便捷和舒適。在安全防護(hù)層面,自定義鍵盤可以
    的頭像 發(fā)表于 06-05 14:19 ?438次閱讀

    LabVIEW運(yùn)動(dòng)控制(三):EtherCAT運(yùn)動(dòng)控制器的高效加工指令自定義封裝

    LabVIEW高效加工指令自定義封裝
    的頭像 發(fā)表于 04-08 13:49 ?2313次閱讀
    LabVIEW運(yùn)動(dòng)控制(三):EtherCAT運(yùn)動(dòng)控制器的高效加工指令<b class='flag-5'>自定義</b><b class='flag-5'>封裝</b>

    如何添加自定義單板

    在開發(fā)過程中,用戶有時(shí)需要?jiǎng)?chuàng)建自定義板配置。本節(jié)將通過一個(gè)實(shí)例講解用戶如何創(chuàng)建屬于自己的machine,下面以g2l-test.conf為例進(jìn)行說明。
    的頭像 發(fā)表于 03-12 14:43 ?513次閱讀

    如何快速創(chuàng)建用戶自定義Board和App工程

    概述自HPM_SDKv1.7.0發(fā)布開始,在HPM_ENV中新增了user_template文件夾,以方便用戶快速創(chuàng)建自定義的Board和App工程。user_template是用戶模板工程,用戶
    的頭像 發(fā)表于 02-08 13:38 ?437次閱讀
    如何快速創(chuàng)建用戶<b class='flag-5'>自定義</b>Board和App工程

    Altium Designer 15.0自定義元件設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《Altium Designer 15.0自定義元件設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 01-21 15:04 ?0次下載
    Altium Designer 15.0<b class='flag-5'>自定義</b>元件設(shè)計(jì)

    think-cell:自定義think-cell(四)

    C.5 設(shè)置默認(rèn)議程幻燈片布局 think-cell 議程可以在演示文稿中使用特定的自定義布局來定義議程、位置和議程幻燈片上的其他形狀,例如標(biāo)題或圖片。通過將此自定義布局添加到模板,您可以為整個(gè)組織
    的頭像 發(fā)表于 01-13 10:37 ?469次閱讀
    think-cell:<b class='flag-5'>自定義</b>think-cell(四)

    智能語音識(shí)別照明解決方案,平臺(tái)自定義,中英切換

    智能語音識(shí)別照明方案引入NRK3502芯片,支持平臺(tái)自定義,離線控制,中英雙語切換。NRK3502具備高性能和靈活自定義能力,可推動(dòng)智能照明革新,控制其他智能設(shè)備,為國際用戶提供全方位智能生活體驗(yàn)。
    的頭像 發(fā)表于 01-10 13:23 ?385次閱讀
    智能語音識(shí)別照明解決方案,平臺(tái)<b class='flag-5'>自定義</b>,中英切換

    think-cell;自定義think-cell(一)

    布局介紹了如何創(chuàng)建自定義議程幻燈片布局,第六部分 C.6 功能區(qū)自定義 介紹了如何使用 PowerPoint 的功能區(qū)自定義選項(xiàng)自定義 think-cell 的用戶界面。 可以使用樣式
    的頭像 發(fā)表于 01-08 11:31 ?645次閱讀
    think-cell;<b class='flag-5'>自定義</b>think-cell(一)

    TPS659xx應(yīng)用程序自定義工具

    電子發(fā)燒友網(wǎng)站提供《TPS659xx應(yīng)用程序自定義工具.pdf》資料免費(fèi)下載
    發(fā)表于 11-06 10:02 ?0次下載
    TPS659xx應(yīng)用程序<b class='flag-5'>自定義</b>工具

    創(chuàng)建自定義的基于閃存的引導(dǎo)加載程序(BSL)

    電子發(fā)燒友網(wǎng)站提供《創(chuàng)建自定義的基于閃存的引導(dǎo)加載程序(BSL).pdf》資料免費(fèi)下載
    發(fā)表于 09-19 10:50 ?0次下載
    創(chuàng)建<b class='flag-5'>自定義</b>的基于閃存的引導(dǎo)加載程序(BSL)

    如何創(chuàng)建TestStand自定義步驟

    在之前的課程中簡(jiǎn)單地介紹過TestStand自帶的一些步驟類型,如測(cè)試、消息彈窗、賦值、標(biāo)簽等等,這些簡(jiǎn)單的步驟從TestStand的插入選版中就可以添加到序列中。那么在使用中如果碰到需要實(shí)現(xiàn)更加靈活、復(fù)雜的功能,使用自帶的一些步驟類型可能難以滿足,這時(shí)就需要使用到自定義步驟。
    的頭像 發(fā)表于 09-11 14:46 ?2262次閱讀
    如何創(chuàng)建TestStand<b class='flag-5'>自定義</b>步驟

    EtherCAT運(yùn)動(dòng)控制器PT/PVT實(shí)現(xiàn)用戶自定義軌跡規(guī)劃

    EtherCAT運(yùn)動(dòng)控制器PT/PVT實(shí)現(xiàn)用戶自定義軌跡規(guī)劃。
    的頭像 發(fā)表于 08-15 11:49 ?1137次閱讀
    EtherCAT運(yùn)動(dòng)控制器PT/PVT實(shí)現(xiàn)用戶<b class='flag-5'>自定義</b>軌跡規(guī)劃

    NVIDIA NeMo加速并簡(jiǎn)化自定義模型開發(fā)

    如果企業(yè)希望充分發(fā)揮出 AI 的力量,就需要根據(jù)其行業(yè)需求量身定制的自定義模型。
    的頭像 發(fā)表于 07-26 11:17 ?1179次閱讀
    NVIDIA NeMo加速并簡(jiǎn)化<b class='flag-5'>自定義</b>模型開發(fā)
    主站蜘蛛池模板: 91大神大战高跟丝袜美女 | 亚洲午夜精品久久久久 | bl 高h文| 国产嫩草影院精品免费网址 | 免费一级黄 | 中国美女乱淫免费看视频 | 好硬好大好爽女房东在线观看 | 黄页网站视频免费 视频 | 午夜寂寞在线一级观看免费 | 久久久久久久综合色一本 | 午夜免费免费啪视频观看 | 欧美在线视频免费 | 欧美同性精品xxxx | 久久天天躁综合夜夜黑人鲁色 | 色天天综合网 | www.87福利| 日本免费不卡视频一区二区三区 | 亚洲夜夜操 | 精品久久久久久久久久 | 久久99精品久久久久久园产越南 | 四虎国产一区二区三区 | 很黄很黄叫声床戏免费视频 | 午夜在线免费观看视频 | 青草青视频在线观看 | 四虎影院最新 | 亚洲国产七七久久桃花 | 国产天天色 | 成人a在线 | 国产精品免费久久久久影院 | 国产va在线播放 | 四虎免费影院在线播放 | 日韩a毛片| 男女性高爱潮免费的国产 | 免费激情网址 | 亚洲日本一区二区三区在线不卡 | 亚洲大成色www永久网 | 欧美一级淫片免费播放口 | 123456成年免费视频 | 狠狠去 | 久久久久久久综合色一本 | 国产精品视频久久久久 |