【微信小程序-原生开发】实用教程16 - 查看详情(含页面跳转的传参方法--简单传参 vs 复杂传参)

简介: 【微信小程序-原生开发】实用教程16 - 查看详情(含页面跳转的传参方法--简单传参 vs 复杂传参)

需在实现列表的基础上开发

【微信小程序-原生开发】实用教程15 - 列表的排序、搜索(含云数据库常用查询条件的使用方法,t-search 组件的使用)_朝阳39的博客-CSDN博客

https://sunshinehu.blog.csdn.net/article/details/129356909

效果预览

技术要点

详情的获取有两种方式:

方式一:通过 id 获取详情

优点:可以确保每次打开详情都是最新的内容

缺点:需要访问详情接口,会消耗调用次数和客户流量

以查看成员详情为例

    <t-cell url="{{'/pages/components/friend/detail/index?id='+item.memberID}}" align='top' leftIcon="user-add" wx:if="{{item.type === 3}}" title="{{'热烈欢迎 '+item.publisher+' 加入DOS圆梦大家庭!'}}" />
  • t-cell 组件的 url 属性可以直接实现页面跳转,效果同 wx.navigateTo

当然,也可以绑定点击事件,触发页面跳转

bindtap="gotoDetail" data-detail="{{item}}"
 
    gotoDetail(e) {
      let memberID = e.currentTarget.dataset.detail._id
      wx.navigateTo({
        url: '/pages/components/friend/detail/index?id='+ memberID
      })
    }

以上为在目标页面路径后添加参数的方式,实现页面传参,仅适用于参数内容少,且为字符串等基础数据类型的参数。(若是对象等复杂类型则不适合此种方式的页面传参)

详情页接收参数并查询详情

在页面生命周期 onLoad 方法中,接收来自上个页面通过页面路径传来的参数

onLoad(options) {
    // 通过id获取详情
    let id = options.id
    if (id) {
      this.setData({
        id: id
      })
      this.getDetail()
      return
    }
}
  getDetail() {
    let that = this
    that.setData({
      show: false
    })
    wx.showLoading({
      title: '加载中',
    })
    db.doc(this.data.id).get().then(res => {
      that.setData({
        detail: res.data,
        show: true
      })
      wx.hideLoading()
    }).catch(() => {
      that.setData({
        show: true
      })
      wx.hideLoading()
    })
  },

方式二:直接从列表传递详情

优点:无需访问接口,可节省调用次数和客户流量

缺点:查看的内容为获取当前列表时得到的详情内容,可能已不是最新的数据内容。

当页面跳转需传递复杂参数(如对象)时,则需采用以下方式

    gotoDetail(e) {
      let detail = e.currentTarget.dataset.detail
      wx.navigateTo({
        url: '/pages/components/friend/detail/index',
        success: function (res) {
          res.eventChannel.emit('sendData', {
            data: detail
          })
        }
      })
    }

详情页接收此种参数的方法如下:

  onLoad() {
    let that = this
    // 接收列表页传入的复杂数据--对象(详情)
    const eventChannel = this.getOpenerEventChannel()
    eventChannel.on('sendData', function (res) {
      that.setData({
        id: res.data._id,
        detail: res.data,
        show: true
      })
    })
  },

目录
相关文章
|
4月前
|
人工智能 小程序 前端开发
小程序、网站 vs. APP:成本差异究竟在哪里?技术栈如何决定项目上限?优雅草卓伊凡
小程序、网站 vs. APP:成本差异究竟在哪里?技术栈如何决定项目上限?优雅草卓伊凡
334 0
小程序、网站 vs. APP:成本差异究竟在哪里?技术栈如何决定项目上限?优雅草卓伊凡
|
8月前
|
Web App开发 移动开发 小程序
公众号小程序H5网页像素流送UE5模型的方法分享
本文探讨了如何通过像素流送技术在小程序、公众号等平台展示复杂的3D模型(如UE5引擎开发的楼盘模型、数字孪生展厅)。该技术将GPU和CPU算力需求转移到服务器端,使用户侧无需高性能硬件即可流畅体验。通过Webrtc实现实时云渲染,确保毫秒级响应,且兼容多种浏览器。使用点量云流等产品级软件,老项目只需重新打包为EXE格式,即可轻松嵌入H5网页、小程序或公众号中,支持Unity、WebGL等多种3D应用及传统CAD模型。
281 1
|
小程序
小程序消除图片下边距的三个方法
小程序消除图片下边距的三个方法
435 167
|
9月前
|
缓存 小程序 API
微信小程序页面导航与路由:实现多页面跳转与数据传递
本文深入探讨微信小程序的页面导航与路由机制,介绍多种页面跳转方式如`wx.navigateTo`、`wx.redirectTo`、`wx.switchTab`等,并讲解通过URL、全局变量和事件传递数据的方法。结合案例实现多页面跳转与数据传递,帮助开发者掌握这一重要技能。
|
小程序 安全
Fiddler抓取小程序后端请求导入AppScan扫描快捷方法
【8月更文挑战第26天】这是一种利用 Fiddler 捕获小程序后端请求并导入 AppScan 进行安全扫描的方法。首先安装配置 Fiddler 并设置手机代理,通过 Fiddler 捕获请求;接着导出这些请求为 .saz 文件,并在 AppScan 中导入此文件,配置扫描参数后启动扫描以检测安全漏洞。操作时需确保有合法授权并遵循相关法规。尽管不同版本软件操作细节可能有所不同,但整体流程类似。
625 1
|
小程序 JavaScript API
小程序实现分享的三种方法
【8月更文挑战第20天】
|
2月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
3月前
|
小程序 JavaScript API
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
这篇文章介绍了使用uni-halo框架进行微信小程序开发的过程,包括选择该框架的原因、开发目标以及项目配置和部署的步骤。
168 0
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
|
9月前
|
自然语言处理 搜索推荐 小程序
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。
|
6月前
|
小程序 前端开发 Android开发
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
1406 29
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡

热门文章

最新文章

下一篇
oss云网关配置