公交车上荫蒂添的好舒服的电影-公用玩物(np双xing总受)-公用小荡货芊芊-公与妇仑乱hd-攻把受做哭边走边肉楼梯play-古装一级淫片a免费播放口

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

頁面跳轉如何優雅攜帶大數據Array或Object

admin
2024年12月19日 12:24 本文熱度 896

本文轉載于稀土掘金技術社區,作者:不愛說話郭德綱

https://juejin.cn/post/7433271555830431784

前言

  • 在小程序或者app開發中,最常用到的就是頁面跳轉,上文中詳細介紹了頁面跳轉4種方法的區別和使用,可以點擊查看??分析小程序頁面導航與事件通訊[1]
  • 而頁面跳轉就經常會攜帶數據到下一個頁面,常見的做法是通過 URL 參數將數據拼接在 navigateTo 的 URL 后面。然而,這種方式在處理較大數據(如數組或對象)時會顯得笨拙且有限。
  • 下面將討論通過 URL 傳遞參數的局限性,以及使用 EventChannel 進行數據傳遞的好處,并提供代碼示例進行解析。

一、使用 URL 參數傳遞數據的局限性

在小程序中,我們通常使用 navigateTo 方法來跳轉到另一個頁面,并通過 URL 傳遞參數。例如:

// 使用 URL 參數進行頁面跳轉
wx.navigateTo({
  url'/pages/target/target?name=John&age=30'
});

1.1 問題

  1. 數據大小限制:URL 的長度限制通常在 2000 字符左右。如果需要傳遞一個較大的數據結構(例如一個包含大量信息的對象或數組),URL 會迅速達到限制,導致無法完整傳遞數據。
  2. 編碼和解析:當數據包含特殊字符(如空格、&、=等)時,必須進行編碼處理。這增加了編碼和解析的復雜性,不夠直觀。
  3. 可讀性差:長的 URL 會導致可讀性降低,特別是當需要傳遞多個參數時,容易讓人困惑。

二、使用 EventChannel 的優勢

相比之下,使用 EventChannel 可以更優雅地在頁面之間傳遞數據,尤其是復雜的數據結構。以下是使用 EventChannel 的幾個主要優點:

  1. 支持復雜數據類型:可以直接傳遞對象和數組,無需擔心 URL 長度限制或特殊字符的編碼問題。
  2. 簡化代碼:代碼更簡潔,邏輯更清晰,特別是在需要傳遞多個參數時。
  3. 即時通信:在新頁面創建后,可以立即接收數據,使得頁面間的交互更加流暢。

三、示例代碼解析

3.1 在源頁面中

在源頁面中,我們可以使用 EventChannel 傳遞數組和對象:

// 源頁面
wx.navigateTo({
  url'/pages/target/target',
  events: {
    // 監聽目標頁面發送的消息
    someEvent(data) {
      console.log(data); // 可以在這里處理目標頁面返回的數據
    }
  },
  success(res) => {
    // 創建要傳遞的復雜數據
    const arrayData = [12345];
    const objectData = { key'value'info: { nestedKey'nestedValue' } };

    // 通過 EventChannel 向目標頁面傳遞數據
    res.eventChannel.emit('someEvent', {
      array: arrayData,
      object: objectData,
    });
  }
});

3.2 在目標頁面中

在目標頁面中,我們接收并使用傳遞的數據:

// 目標頁面
const eventChannel = this.getOpenerEventChannel();
eventChannel.on('someEvent', (data) => {
  // 接收數組和對象數據
  console.log(data.array);  // [1, 2, 3, 4, 5]
  console.log(data.object);  // { key: 'value', info: { nestedKey: 'nestedValue' } }

  // 進行相應的數據處理
  // 例如,渲染數據到頁面上
  this.setData({
    receivedArray: data.array,
    receivedObject: data.object,
  });
});

四、總結

通過使用 EventChannel 進行頁面間的數據傳遞,我們可以避免使用 URL 傳遞參數時面臨的各種局限性,特別是在處理復雜數據時。EventChannel 使得數據傳遞變得更加靈活、簡潔和高效,提升了小程序的用戶體驗。

在實際開發中,傳遞較少數據時,可以在url后面拼接參數進行傳遞使用。當需要攜帶大數據時可以考慮使用 EventChannel 進行復雜數據的傳遞,確保應用的交互更加順暢。


該文章在 2024/12/19 17:41:42 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: aⅴ不卡国产在线观看 | 国产成人无码a片免费男男中文 | 国产一卡二卡三卡 | 国产精品一区二区在线观看麻 | 成年无码动漫av片在线观看 | 成人无码a区在线观看视 | 国产成人无码āā精品一区 | 国产精品白浆精子流水 | 国产精品日韩无码一区二区 | 国产aⅴ无码专区亚洲av麻豆 | 国产毛片片精品天天看视频 | 911亚洲精视频 | 国产毛多水多高潮高清 | 2025无码专区人妻系列制服丝袜 | 精品国产av一区二区三 | 精品国产福利在线观看91啪 | 91麻豆精品国产自产 | 国产成人午夜精品影院 | 国产无码不卡在线观看 | 国产精品无码一级毛片不卡 | 国产对白俱乐部交换在线播放 | 91精品国产91久久久久 | 不卡的在线免费视频 | 国产美女自慰在线观看 | 国产精品无码电影在线观 | 成人在线免费网站 | 99国产精品99久久久久 | 国产日韩欧美东南亚在线 | 国产一级毛片 | 国产成人精品影视 | 福利一区二区在线观看 | 2025国自产拍精品高潮视频 | 国产精口品美女乱子伦高潮 | 国产无码一区二去三区 | 国产av一区二区三区久久精品 | 成人午夜精品视频在线观看 | 国产激情一区二区三区四区 | 国产午夜精品一区二区三区小说 | 国产精品国偷自产在线 | 国内国外日产一区二区 | 精品国产亚一区二区三区不卡 |