【微信小程序-原生开发】实用教程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
      })
    })
  },

目录
相关文章
|
11月前
|
JSON 机器人 API
gewe微信机器人搭建教程
GeWe开放平台是基于 微信开放平台的二次封装API服务,开发者可以使用本服务来处理微信中的各种事件,并可以通过后台调用对应的 API 来驱动微信自动执行任务,如自动收发消息、自动化应答、自动群邀请、群管理等,封装了 RPA技术流程,简化开发者二次开发难度,提供了开发者与微信对接的能力,使用简单,操作快捷,支持多种语言接入。
666 17
|
人工智能 开发框架 机器人
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
AstrBot 是一个开源的多平台聊天机器人及开发框架,支持多种大语言模型和消息平台,具备多轮对话、语音转文字等功能。
7940 38
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
|
10月前
|
数据安全/隐私保护
陌陌头像留V的最好方法,陌陌最新留QQ号技巧,陌陌动态最聪明的留微信
本资料分享社交平台隐秘留联系方式的方法,包含微信头像艺术化处理、二维码变形术,以及QQ号谐音替换、图片分割等技巧。
|
编解码 小程序
微信小程序11177版本开启控制台方法
微信小程序11177版本开启控制台方法
|
存储 API UED
鸿蒙特效教程02-微信语音录制动画效果实现教程
本教程适合HarmonyOS初学者,通过简单到复杂的步骤,一步步实现类似微信APP中的语音录制动画效果。
471 0
鸿蒙特效教程02-微信语音录制动画效果实现教程
|
缓存 小程序 API
微信小程序页面导航与路由:实现多页面跳转与数据传递
本文深入探讨微信小程序的页面导航与路由机制,介绍多种页面跳转方式如`wx.navigateTo`、`wx.redirectTo`、`wx.switchTab`等,并讲解通过URL、全局变量和事件传递数据的方法。结合案例实现多页面跳转与数据传递,帮助开发者掌握这一重要技能。
|
XML 小程序 前端开发
小程序制作教程
小程序制作教程
1590 3
小程序制作教程
|
小程序 JavaScript
微信小程序中的页面跳转(通过点击按钮、调用方法的形式)
这篇文章讲解了微信小程序中页面跳转的方法,包括使用按钮点击事件和调用方法实现跳转,以及推荐使用`this.pageRouter.navigateTo`代替`wx.navigateTo`的方式。
微信小程序中的页面跳转(通过点击按钮、调用方法的形式)
详细教程:扫码提交表单后,数据直接推送到企业微信、钉钉、飞书群聊
在草料制作的表单中,填表人扫码填写并提交数据后,这些信息可以立即通过企业微信、钉钉或飞书自动推送到相应的群聊中,实现即时共享和沟通,提升团队协作效率。
723 2

热门文章

最新文章