国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。

這篇具有很好參考價值的文章主要介紹了OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

介紹

本示例分別通過onItemDrop()和onDrop()回調(diào),實現(xiàn)子組件在Grid和List中的子組件位置交換。

效果圖預(yù)覽

OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。,HarmonyOS,OpenHarmony,鴻蒙,harmonyos,OpenHarmony,鴻蒙應(yīng)用開發(fā),鴻蒙,鴻蒙開發(fā),鴻蒙系統(tǒng),HarmonyOS
使用說明:

  1. 拖拽Grid中子組件,到目標Grid子組件位置,進行兩者位置互換。
  2. 拖拽List中子組件,到目標List子組件位置,進行兩者位置互換。

實現(xiàn)思路

1.在Grid組件中,通過editMode()打開編輯模式、通過onItemDragStart()指定拖拽時樣式、通過onItemDrop()指定拖拽釋放時的行為。

Grid() { ... }
.editMode(true) // 設(shè)置Grid進入編輯模式
.onItemDragStart((event: ItemDragInfo, itemIndex: number) => { // 設(shè)置拖拽過程中顯示的圖形
  this.movedItem = this.appInfoList[itemIndex]; // 記錄原位置子組件信息
  return this.itemWhileDrag(); 
})
.onItemDrop((event: ItemDragInfo, itemIndex: number, insertIndex: number, isSuccess: boolean) => { // 拖拽釋放時,觸發(fā)回調(diào)
  // isSuccess=false時,說明drop的位置在grid外部;insertIndex > length時,說明有新增元素的事件發(fā)生
  if (isSuccess && insertIndex < this.appInfoList.length) {
    this.changeIndex(itemIndex, insertIndex); // 互換子組件index值
  }
})

2.在List組件中,通過ListItem的onDragStart()方法指定拖拽開始時的行為,通過List的onTouch()指定拖拽釋放時的行為。

List({ space: LIST_SPACE }) {
  ForEach(this.appInfoList, (item: AppInfo, index) => {
    ListItem() { ... }
    .onDragStart(() => {
      item.visible = false; // 拖拽時,設(shè)置子組件原位置圖標不可見
    })
    .onTouch((event: TouchEvent) => { // 拖拽釋放時,記錄目標位置子組件index值
      if (event.type === TouchType.Down) {
        this.dragIndex = index;
      }
    })
  })
}
.onDrop((event: DragEvent, extraParams: string) => {
  let jsonString: JsonObjType = JSON.parse(extraParams) as JsonObjType; // 通過參數(shù)extraParams獲取原位置子組件index值
  this.changeIndex(this.dragIndex, jsonString.insertIndex); // 互換子組件index值
  this.appInfoList[jsonString.insertIndex].visible = true; // 完成互換后,設(shè)置子組件原位置圖標不可見
})

高性能知識點

不涉及

模塊依賴

@ohos/routermodule(動態(tài)路由)

工程結(jié)構(gòu)&模塊類型

dragandexchange                  // har類型               
|---pages                                       
|---|---Launcher.ets             // 頁面層-方案主頁面
|---view                                        
|---|---GridSceneView.ets        // 視圖層-Grid拖拽頁面             
|---|---ListSceneView.ets        // 視圖層-List拖拽頁面  
|---model                                     
|---|---AppInfo.ets              // 模型層-App信息模型 

如果大家還沒有掌握鴻蒙,現(xiàn)在想要在最短的時間里吃透它,我這邊特意整理了《鴻蒙開發(fā)學(xué)習(xí)手冊》(共計890頁),希望對大家有所幫助:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

《鴻蒙開發(fā)學(xué)習(xí)手冊》:

如何快速入門:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.基本概念
2.構(gòu)建第一個ArkTS應(yīng)用
3.……

OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。,HarmonyOS,OpenHarmony,鴻蒙,harmonyos,OpenHarmony,鴻蒙應(yīng)用開發(fā),鴻蒙,鴻蒙開發(fā),鴻蒙系統(tǒng),HarmonyOS

開發(fā)基礎(chǔ)知識:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.應(yīng)用基礎(chǔ)知識
2.配置文件
3.應(yīng)用數(shù)據(jù)管理
4.應(yīng)用安全管理
5.應(yīng)用隱私保護
6.三方應(yīng)用調(diào)用管控機制
7.資源分類與訪問
8.學(xué)習(xí)ArkTS語言
9.……

OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。,HarmonyOS,OpenHarmony,鴻蒙,harmonyos,OpenHarmony,鴻蒙應(yīng)用開發(fā),鴻蒙,鴻蒙開發(fā),鴻蒙系統(tǒng),HarmonyOS

基于ArkTS 開發(fā):https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

1.Ability開發(fā)
2.UI開發(fā)
3.公共事件與通知
4.窗口管理
5.媒體
6.安全
7.網(wǎng)絡(luò)與鏈接
8.電話服務(wù)
9.數(shù)據(jù)管理
10.后臺任務(wù)(Background Task)管理
11.設(shè)備管理
12.設(shè)備使用信息統(tǒng)計
13.DFX
14.國際化開發(fā)
15.折疊屏系列
16.……

OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。,HarmonyOS,OpenHarmony,鴻蒙,harmonyos,OpenHarmony,鴻蒙應(yīng)用開發(fā),鴻蒙,鴻蒙開發(fā),鴻蒙系統(tǒng),HarmonyOS

鴻蒙語法ArkTS、TypeScript、ArkUI等…視頻教程:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。,HarmonyOS,OpenHarmony,鴻蒙,harmonyos,OpenHarmony,鴻蒙應(yīng)用開發(fā),鴻蒙,鴻蒙開發(fā),鴻蒙系統(tǒng),HarmonyOS

鴻蒙生態(tài)應(yīng)用開發(fā)白皮書V2.0PDF:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。,HarmonyOS,OpenHarmony,鴻蒙,harmonyos,OpenHarmony,鴻蒙應(yīng)用開發(fā),鴻蒙,鴻蒙開發(fā),鴻蒙系統(tǒng),HarmonyOS

HarmonyOS APP開發(fā)教程案列:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3

OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。,HarmonyOS,OpenHarmony,鴻蒙,harmonyos,OpenHarmony,鴻蒙應(yīng)用開發(fā),鴻蒙,鴻蒙開發(fā),鴻蒙系統(tǒng),HarmonyOS文章來源地址http://www.zghlxwxcb.cn/news/detail-854237.html

到了這里,關(guān)于OpenHarmony實戰(zhàn)開發(fā)-Grid和List內(nèi)拖拽交換子組件位置。的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • OpenHarmony開發(fā)實戰(zhàn):switch、chart組件的使用(JS)

    OpenHarmony開發(fā)實戰(zhàn):switch、chart組件的使用(JS)

    本篇文章基于switch組件和chart組件,實現(xiàn)線形圖、占比圖、柱狀圖,并通過switch切換chart組件數(shù)據(jù)的動靜態(tài)顯示。要求實現(xiàn)以下功能: 實現(xiàn)靜態(tài)數(shù)據(jù)可視化圖表。 打開開關(guān),實現(xiàn)靜態(tài)圖切換為動態(tài)可視化圖表。 相關(guān)概念 switch組件:開關(guān)選擇器,通過開關(guān),開啟或關(guān)閉某個功

    2024年04月11日
    瀏覽(42)
  • Grid 拖拽布局實現(xiàn)

    Grid 拖拽布局實現(xiàn)

    最近有個需求需要實現(xiàn)自定義首頁布局,需要將屏幕按照 6 列 4 行進行等分成多個格子,然后將組件可拖拽對應(yīng)格子進行渲染展示。 示例 對比一些已有的插件,發(fā)現(xiàn)想要實現(xiàn)產(chǎn)品的交互效果,沒有現(xiàn)成可用的。本身功能并不是太過復(fù)雜,于是決定自己基于 vue 手擼一個簡易的

    2024年02月05日
    瀏覽(22)
  • 手擼前端 Grid 拖拽布局

    手擼前端 Grid 拖拽布局

    最近有個需求需要實現(xiàn)自定義首頁布局,需要將屏幕按照 6 列 4 行進行等分成多個格子,然后將組件可拖拽對應(yīng)格子進行渲染展示。 示例 對比一些已有的插件,發(fā)現(xiàn)想要實現(xiàn)產(chǎn)品的交互效果,沒有現(xiàn)成可用的。本身功能并不是太過復(fù)雜,于是決定自己基于 vue 手擼一個簡易的

    2024年02月05日
    瀏覽(25)
  • 鴻蒙開發(fā)OpenHarmony組件復(fù)用案例

    鴻蒙開發(fā)OpenHarmony組件復(fù)用案例

    在開發(fā)應(yīng)用時,有些場景下的自定義組件具有相同的組件布局結(jié)構(gòu),僅有狀態(tài)變量等承載數(shù)據(jù)的差異。這樣的組件緩存起來,需要使用到該組件時直接復(fù)用, 減少重復(fù)創(chuàng)建和渲染的時間,從而提高應(yīng)用頁面的加載速度和響應(yīng)速度。 在OpenHarmony應(yīng)用開發(fā)時,自定義組件被@Reus

    2024年01月19日
    瀏覽(19)
  • draggable + grid 拖拽插件 + 網(wǎng)格布局 動態(tài)生成首頁模版

    draggable + grid 拖拽插件 + 網(wǎng)格布局 動態(tài)生成首頁模版

    背景: ? ? ? ? 1、首頁模板由多個子組件組成,如圖表、新聞、公告、輪播圖等,一般都由前端引入子組件,寫在固定的位置上,最終形成一個固定的首頁模板; ? ? ? ? 2、像這樣直接在代碼中寫死的首頁沒有靈活性,不同用戶想展示出來的首頁模板千篇一律; ? ? ? ?

    2024年02月01日
    瀏覽(37)
  • OpenHarmony開發(fā)實戰(zhàn):快速入門

    OpenHarmony開發(fā)實戰(zhàn):快速入門

    OpenHarmony是一款面向全場景的開源分布式操作系統(tǒng),采用組件化設(shè)計,支持在128KiB到xGiB RAM資源的設(shè)備上運行系統(tǒng)組件,設(shè)備開發(fā)者可基于目標硬件能力自由選擇系統(tǒng)組件進行集成。 OpenHarmony當(dāng)前定義了三種基礎(chǔ)系統(tǒng)類型,設(shè)備開發(fā)者通過選擇基礎(chǔ)系統(tǒng)類型完成必選組件集配置

    2024年04月17日
    瀏覽(21)
  • 鴻蒙開發(fā)實戰(zhàn)-OpenHarmony沙箱文件

    鴻蒙開發(fā)實戰(zhàn)-OpenHarmony沙箱文件

    在openharmony文件管理模塊中,按文件所有者分類分為應(yīng)用文件和用戶文件和系統(tǒng)文件。 1)沙箱文件。也叫做應(yīng)用文件,包括應(yīng)用安裝文件、應(yīng)用資源文件、應(yīng)用緩存文件 在使用時首先需要導(dǎo)入包 import fs from “@ohos.file.fs”; 在API9之前使用“@ohos.fileio”,API9之后廢棄。 1.常用

    2024年01月19日
    瀏覽(19)
  • 鴻蒙開發(fā)實戰(zhàn)-OpenHarmony之天氣應(yīng)用

    鴻蒙開發(fā)實戰(zhàn)-OpenHarmony之天氣應(yīng)用

    功能描述: 通過請求免費API獲取指定城市七天內(nèi)相關(guān)天氣信息 開發(fā)環(huán)境: IDE:DEV ECO 4.0.600 SDK:4.0.10.15 開發(fā)板:DAYU200 4.0.10.16 一. 創(chuàng)建項目,調(diào)試環(huán)境 1.創(chuàng)建項目 2.選擇OpenHarmony、API10 3.連網(wǎng)條件下加載依賴 4.在開發(fā)板上簽名,運行HelloWorld測試環(huán)境 直接運行,然后點擊log報錯直

    2024年02月21日
    瀏覽(12)
  • OpenHarmony開發(fā)實戰(zhàn):深入了解開發(fā)版-RK3568

    OpenHarmony開發(fā)實戰(zhàn):深入了解開發(fā)版-RK3568

    RK3568開發(fā)板基于Rockchip RK3568芯片,集成雙核心架構(gòu)GPU以及高效能NPU;搭載四核64位Cortex-A55處理器,采用22nm先進工藝,主頻高達2.0GHz;支持藍牙、Wi-Fi、音頻、視頻和攝像頭等功能,擁有豐富的擴展接口,支持多種視頻輸入輸出接口;配置雙千兆自適應(yīng)RJ45以太網(wǎng)口,可滿足NV

    2024年04月29日
    瀏覽(94)
  • HarmonyOS/OpenHarmony(Stage模型)卡片開發(fā)AbilityStage組件容器

    AbilityStage是一個Module級別的組件容器,應(yīng)用的HAP在首次加載時會創(chuàng)建一個AbilityStage實例,可以對該Module進行初始化等操作。 AbilityStage與Module一一對應(yīng),即一個Module擁有一個AbilityStage。 DevEco Studio默認工程中未自動生成AbilityStage,如需要使用AbilityStage的能力,可以手動新建一個

    2024年02月11日
    瀏覽(22)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包