色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

OpenHarmony開發實例:【新聞客戶端】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-16 16:09 ? 次閱讀

介紹

本篇Codelab我們將教會大家如何構建一個簡易的OpenHarmony新聞客戶端(JS版本)。應用包含兩級頁面,分別是主頁面和詳情頁面,兩個頁面都展示了豐富的UI組件,其中詳情頁的實現邏輯中還展示了如何通過調用相應接口,實現跨設備拉起FA。本教程將結合以下內容進行講解:

1.頂部tabs以及新聞列表list的使用

2.每條新聞的文本框以及圖像

3.布局及頁面跳轉

4.設備發現以及跨設備拉起FA

最終效果預覽如下圖所示:

搭建OpenHarmony環境

完成本篇Codelab我們首先要完成開發環境的搭建,本示例以Hi3516DV300開發板為例,參照以下步驟進行:

  1. [獲取OpenHarmony系統版本]:標準系統解決方案(二進制)。
  2. 搭建燒錄環境:
    1. [完成DevEco Device Tool的安裝]
    2. [完成Hi3516開發板的燒錄]
    3. 鴻蒙開發指導文檔:[qr23.cn/AKFP8k]
  3. 搭建開發環境:
    1. 開始前請參考[工具準備] ,完成DevEco Studio的安裝和開發環境配置。
    2. 開發環境配置完成后,請參考[使用工程向導] 創建工程(模板選擇“Empty Ability”),選擇JS或者eTS語言開發。
    3. 工程創建完成后,選擇使用[真機進行調測] 。

搜狗高速瀏覽器截圖20240326151344.png

分布式組網

完成本篇Codelab我們還需要完成開發板的分布式組網,本示例以Hi3516DV300開發板為例,參照以下步驟進行:

  1. 硬件準備:準備兩臺燒錄相同的版本系統的Hi3516DV300開發板A、B。

  2. 兩個開發板A、B配置在同一個WiFi網絡之下。
    打開設置-->WLAN-->點擊右側WiFi開關-->點擊目標WiFi并輸入密碼。

  3. 將設備A、B設置為互相信任的設備。

    • 找到系統應用“音樂”。

    • 設備A打開音樂,點擊左下角帶箭頭的流轉按鈕,彈出列表框,在列表中會展示遠端設備的id。
    • 選擇遠端設備B的id,另一臺開發板(設備B)會彈出驗證的選項框。
    • 設備B點擊允許,設備B將會彈出隨機PIN碼,將設備B的PIN碼輸入到設備A的PIN碼填入框中。

    配網完畢。

代碼結構解讀

本篇Codelab只對核心代碼進行講解,對于完整代碼,我們會在最后的參考中提供下載方式,接下來我們會用一小節來講解整個工程的代碼結構:

  • images:存放工程使用到的圖片資源。
  • index:構成新聞列表頁面,包括index.hml布局文件、index.css樣式文件、index.js邏輯處理文件。
  • detail:構成新聞詳情頁面,包括detail.hml布局文件、detail.css樣式文件、detail.js邏輯處理文件。
  • config.json:配置文件。

添加主頁新聞類型

首先為我們的應用添加頂部新聞類型,用于切換不同類別的新聞。這里會使用到tabs、tab-bar控件,同時使用for循環對新聞的title進行遍歷,新聞的標題有All、Health、Finance、Technology、Sport、Internet、Game七大類。圖片示例和代碼如下:

< div class="container" >
    < tabs index="0" vertical="false" onchange="changeNewsType" >
        < tab-bar class="tab-bar" mode="scrollable" >
            < text class="tab-text" for="{{ title in titleList }}" >{{ title.name }} < /text >
        < /tab-bar >
    < /tabs >
< /div >

添加主頁頂部新聞類型

  1. 我們需要實現一個新聞item的布局,其樣式包含左邊的新聞標題、右邊的新聞圖片以及下方的新聞分割線,圖片示例和代碼如下:
    < div style="flex-direction : column" >
        < div style="flex-direction : row" >
              < text class="text" >
                  {{ news.title }}
              < /text >
              < image class="image" src="{{ news.imgUrl }}" >
                  < /image >
              < /div >
         < div style="height : 2px; width : 100%; background-color : #97d2d4d4;" >
         < /div >
     < /div >
    
  2. 我們需要實現一個新聞列表,也就是將上方的新聞item進行一個循環的展示,這需要用到list、list-item的相關知識點。我們需要將newsList新聞列表數據進行循環,所以新聞item的布局外層需要嵌套一個list和list-item,圖片示例和代碼如下:
    < list class="list" >
        < list-item for="{{ news in newsList }}" onclick="itemClick(news)" >
               // 新聞item的布局代碼填充到這里         
        < /list-item >
    < /list >
    
  3. 我們需要實現新聞類型的切換,每一條新聞都會有一個新聞類型,當選擇All的時候默認展示所有類型的新聞,當選擇具體的新聞類型時,如選擇Health,則需要篩選出屬于Health類型的新聞進行展示。添加一個自定義函數changeNewsType,代碼如下所示:
    // 選擇新聞類型
    changeNewsType: function (e) {
      const type = titles[e.index].name;
      this.newsList = [];
      if (type === 'All') {
        // 展示全部新聞
        this.newsList = newsData;
      } else {
        // 分類展示新聞
        const newsArray = [];
        for (var news of newsData) {
           if (news.type === type) {
              newsArray.push(news);
          }
        }
        this.newsList = newsArray;
      }
    }
    

詳情頁頁面布局

詳情頁面包含新聞標題、閱讀量和喜好數、新聞圖片、新聞文字以及下方的狀態欄。狀態欄包括1個可輸入文本框和4個功能按鍵,圖片示例和代碼如下:

< div class="container" >
    < text class="text-title" >{{ title }}< /text >
    < text class="text-reads" >reads: {{ reads }}   likes: {{ likes }}< /text >
    < image class="image" src="{{ imgUrl }}" >< /image >
    < text class="text-content" >
        {{ content }}
    < /text >
    < !-- 詳情頁底部-- >
    < div class="bottom" >
        < textarea class="textarea" placeholder="Enter a comment." >< /textarea >
        < image class="image-bottom" src="/common/images/icon_message.png" >< /image >
        < image class="image-bottom" src="/common/images/icon_star.png" >< /image >
        < image class="image-bottom" src="/common/images/icon_good.png" >< /image >
        < image class="image-bottom" src="/common/images/icon_share.png" onclick="toShare" >< /image >
    < /div >
< /div >

需要注意的是detail.hml只是展示了頁面的布局結構,其具體的布局樣式需要參考detail.css文件。

跳轉詳情頁

完成新聞列表頁面和詳情頁的布局后,需要實現頁面跳轉的功能。新聞列表頁面中綁定一個list-item的點擊事件itemClick,其中傳入的參數是news(新聞的詳細數據)。

< list-item for="{{ news in newsList }}" onclick="itemClick(news)" >

在JS中頁面跳轉需要在JS文件的頭部引入如下一行代碼:

import router from '@system.router';

實現list-item的點擊事件itemClick,其代碼如下所示:

itemClick(news) {
  // 跳轉到詳情頁面
  router.push({
    uri: 'pages/detail/detail',
    params: {
      'title': news.title,
      'type': news.type,
      'imgUrl': news.imgUrl,
      'reads': news.reads,
      'likes': news.likes,
      'content': news.content
    }
  });
}

設備發現

首先給分享按鈕添加一個分享事件toShare,代碼如下所示:

< image class="image-bottom" src="/common/images/icon_share.png" onclick="toShare" >< /image >

然后調用getTrustedDeviceListSync(),獲取所有可信設備的列表,代碼如下所示:

import deviceManager from '@ohos.distributedHardware.deviceManager';

toShare() {
    // 創建設備管理實例
    deviceManager.createDeviceManager('com.huawei.codelab', (err, data) = > {
      if (err) {
        return;
      }
      this.deviceMag = data;
      // 獲取所有可信設備的列表
      this.deviceList = this.deviceMag.getTrustedDeviceListSync();
    });
    // 循環遍歷設備列表,獲取設備名稱和設備Id
    for (let i = 0; i < this.deviceList.length; i++) {
      this.deviceList[i] = {
        deviceName: this.deviceList[i].deviceName,
        deviceId: this.deviceList[i].deviceId,
        checked: false
      };
    }
    this.$element('showDialog').show();
  }

最后自定義dialog彈窗顯示所有可信設備,代碼如下所示:

< dialog id="showDialog" class="select-device-dialog" >
    < div class="select-device-wrapper" >
        < text class="select-device-title" >選擇設備< /text >
        < list class="select-device-list" >
            < list-item class="select-device-item" for="{{ deviceList }}" id="list" >
                < text class="select-device-item-left" >{{ $item.deviceName }}
                < /text >
                < input class="select-device-item-right" type="checkbox" name="Device" value="{{$idx}}"
                       @change="selectDevice({{$idx}})" checked="{{$item.checked}}" >
                < /input >
            < /list-item >
        < /list >
        < div class="choose-ok-or-not" >
            < text class="select-device-btn" @click="chooseCancel" >取消< /text >
            < text class="select-device-btn" @click="chooseComform" >確定< /text >
         < /div >
    < /div >
< /dialog >

最終實現的效果如下所示:

說明: 本工程項目包含getTrustedDeviceListSync()獲取所有可信設備的列表方法,請選擇API 7或以上版本。

分布式拉起

彈出設備列表后,選擇設備并點擊“確定”按鈕,將會分布式拉起另外一臺設備,其具體實現代碼如下所示:

chooseComform() {
    this.$element('showDialog').close();
    for (let i = 0; i < this.deviceList.length; i++) {
      // 判斷設備是否被選中
      if (this.deviceList[i].checked) {
      const params = {
        url: 'pages/detail/detail',
        title: this.title,
        type: this.type,
        imgUrl: this.imgUrl,
        reads: this.reads,
        likes: this.likes,
        content: this.content,
      };

      const wantValue = {
        bundleName: 'com.huawei.newsdemooh',
        abilityName: 'com.huawei.newsdemooh.MainAbility',
        deviceId: this.deviceList[i].deviceId,
        parameters: params
      };

      featureAbility.startAbility({
        want: wantValue
      }).then((data) = > {
        console.info('featureAbility.startAbility finished, ' + JSON.stringify(data));
      });
      console.info('featureAbility.startAbility want=' + JSON.stringify(wantValue));
      console.info('featureAbility.startAbility end');
      }
    }
}

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 鴻蒙
    +關注

    關注

    57

    文章

    2388

    瀏覽量

    42962
  • HarmonyOS
    +關注

    關注

    79

    文章

    1980

    瀏覽量

    30401
  • OpenHarmony
    +關注

    關注

    25

    文章

    3744

    瀏覽量

    16473
收藏 人收藏

    評論

    相關推薦

    HarmonyOS開發實例:【分布式新聞客戶端

    基于柵格布局、設備管理和多端協同,實現一次開發,多端部署的分布式新聞客戶端頁面。
    的頭像 發表于 04-17 15:57 ?911次閱讀
    HarmonyOS<b class='flag-5'>開發</b><b class='flag-5'>實例</b>:【分布式新聞<b class='flag-5'>客戶端</b>】

    如何使用Socket實現UDP客戶端

    本教程介紹了如何利用socket 編程來實現一個 UDP 客戶端,與服務器進行通信。與開發 TCP 客戶端一樣,我們先將 socket 編程的流程列出來,然后給出具體的實例
    發表于 03-30 07:39

    基于Socket開發TCP傳輸客戶端

    1 程序界面設計 TCP客戶端在上位機開發中應用很廣,大多數情況下,上位機軟件都是作為一個TCP客戶端來與PLC或其他服務器進行通信的。TCP客戶端的主要功能就是連接服務器、發送數據、
    發表于 07-02 06:33

    監控系統客戶端及服務設計

    項目開發報告1 項目簡介1.1 概述1.2 開發環境1.3 其他支持1.4 應用界面1.4.1 服務器1.4.2 客戶端1.5 程序使用2 項目
    發表于 12-21 07:02

    用Delphi開發OPC客戶端工具的方法研究

    本文通過介紹OPC 技術的工作原理,結合OPC 客戶端的工作機制,給出OPC 客戶端開發方法及在的Delphi 的具體實現,提出了OPC 客戶端
    發表于 06-15 10:37 ?35次下載

    基于USB的加密視頻客戶端的設計與實現

    針對USB無線視頻實時接收裝置的開發,論文介紹了在Windows視頻客戶端通過USB數據接口來接收數據,并且通過在Linux服務器將采集的視頻和音頻數據加密,在客戶端進行解密從而保
    發表于 08-31 16:04 ?23次下載

    CoolpyCould客戶端

    一款開源的物聯網服務器平臺,利用nodejs寫成,此文件是CoolpyCould客戶端
    發表于 11-06 17:00 ?18次下載

    CSDN博客客戶端源碼

    CSDN博客客戶端源碼CSDN博客客戶端源碼CSDN博客客戶端源碼
    發表于 11-18 10:22 ?1次下載

    Delphi教程之數據查詢Web服務客戶端開發數據查詢Web服務

    Delphi教程之數據查詢Web服務客戶端開發數據查詢Web服務客戶端開發,很好的Delphi資料,快來下載學習吧。
    發表于 04-11 15:59 ?5次下載

    Android 仿QQ客戶端及服務源碼

    Android 仿QQ客戶端及服務源碼
    發表于 03-19 11:23 ?3次下載

    細說inchat系統客戶端開發之路

    Inchat系統客戶端開發客戶端完成以后,我們將可以進行簡單的交流?!?薇芯bba1887 〗開發完成的程序只是一個很簡單的雛形,在本系統完成以后,InChatter系統
    發表于 08-29 20:36 ?458次閱讀

    iOS淘寶客戶端應用名稱發生變化 Android客戶端應用名稱尚未更改

    iOS淘寶客戶端應用名稱發生變化 Android客戶端應用名稱尚未更改
    發表于 04-18 15:37 ?942次閱讀

    HTTP客戶端快速入門指南

    HTTP客戶端快速入門指南
    發表于 01-12 18:45 ?0次下載
    HTTP<b class='flag-5'>客戶端</b>快速入門指南

    MQTT中服務客戶端

    MQTT 是一種基于客戶端-服務架構(C/S)的消息傳輸協議,所以在 MQTT 協議通信中,有兩個最為重要的角色,它們便是服務客戶端。 1)服務
    的頭像 發表于 07-30 14:55 ?2722次閱讀

    服務如何控制客戶端之間的信息通訊

    服務如何通過“主題”來控制客戶端之間的信息通訊,看下圖實例: 在以上圖示中一共有三個 MQTT 客戶端,它們分別是開發板、手機和電腦。MQ
    的頭像 發表于 07-30 15:10 ?840次閱讀
    服務<b class='flag-5'>端</b>如何控制<b class='flag-5'>客戶端</b>之間的信息通訊
    主站蜘蛛池模板: 一个人在线观看免费中文www| china年轻小帅脸直播飞机| 亚洲国产av| XXXchinese国产HD| 久久久午夜精品福利内容| 色橹| 99久久国产免费福利| 久久超碰色中文字幕| 亚洲 无码 在线 专区| 国产成人a视频在线观看| 青柠在线视频| 中文字幕亚洲男人的天堂网络| 精品国产麻豆AV无码| 午夜精品久久久久久久99蜜桃| 丰满人妻无码AV系列| 清冷受被CAO的合不拢| 国产亚洲精品久久久999无毒| 撕开美女的衣服2| 福利片福利一区二区三区| 亚洲精品久久久992KVTV| 精品国产在线观看福利| 99精品视频在线观看免费播放| 小黄鸭YELLOWDUCK7596| 含羞草影院免费区| 亚洲精品久久无码AV片WWW | 免费毛片网站在线观看| 最新国产亚洲亚洲精品视频 | 娇喘高潮教室h| 伊人久久综合网站| 蜜桃麻豆WWW久久囤产精品免费| 在线亚洲国产日韩欧洲专区| 美女脱了内裤张开腿让男人爽| 国产成人精品在视频| 5566av资源| 女王羞辱丨vk| 边吃胸边膜下床震免费版视频| 人妻 中文无码 中出| 国产成人精品免费视频下载| 2021自产拍在线观看视频| 亚洲爆乳少妇精品无码专区| 秋霞电影院兔费理论84MB|