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

目录
相关文章
|
10月前
|
人工智能 小程序 前端开发
小程序、网站 vs. APP:成本差异究竟在哪里?技术栈如何决定项目上限?优雅草卓伊凡
小程序、网站 vs. APP:成本差异究竟在哪里?技术栈如何决定项目上限?优雅草卓伊凡
577 0
小程序、网站 vs. APP:成本差异究竟在哪里?技术栈如何决定项目上限?优雅草卓伊凡
|
缓存 小程序 API
微信小程序页面导航与路由:实现多页面跳转与数据传递
本文深入探讨微信小程序的页面导航与路由机制,介绍多种页面跳转方式如`wx.navigateTo`、`wx.redirectTo`、`wx.switchTab`等,并讲解通过URL、全局变量和事件传递数据的方法。结合案例实现多页面跳转与数据传递,帮助开发者掌握这一重要技能。
|
XML 小程序 前端开发
小程序制作教程
小程序制作教程
1691 3
小程序制作教程
|
小程序 JavaScript
微信小程序中的页面跳转(通过点击按钮、调用方法的形式)
这篇文章讲解了微信小程序中页面跳转的方法,包括使用按钮点击事件和调用方法实现跳转,以及推荐使用`this.pageRouter.navigateTo`代替`wx.navigateTo`的方式。
微信小程序中的页面跳转(通过点击按钮、调用方法的形式)
|
小程序 PHP
全新UI自助图文打印系统小程序源码 PHP后端 附教程
全新UI自助图文打印系统小程序源码 PHP后端 附教程
789 2
|
前端开发 小程序
【微信小程序-原生开发】实用教程20 - 生成海报(实战范例为生成活动海报,内含生成指定页面的小程序二维码,保存图片到手机,canvas 系列教程)
【微信小程序-原生开发】实用教程20 - 生成海报(实战范例为生成活动海报,内含生成指定页面的小程序二维码,保存图片到手机,canvas 系列教程)
1212 0
|
小程序 前端开发
【微信小程序-原生开发】实用教程22 - 绘制图表(引入 echarts,含图表的懒加载-获取到数据后再渲染图表,多图表加载等技巧)
【微信小程序-原生开发】实用教程22 - 绘制图表(引入 echarts,含图表的懒加载-获取到数据后再渲染图表,多图表加载等技巧)
1446 0
|
小程序
【微信小程序-原生开发】实用教程21 - 分包
【微信小程序-原生开发】实用教程21 - 分包
1004 0
|
小程序 C++
【微信小程序-原生开发】实用教程19 - 表单范例 VS 表单校验(含必填校验函数封装,实时数字校验)
【微信小程序-原生开发】实用教程19 - 表单范例 VS 表单校验(含必填校验函数封装,实时数字校验)
388 0
|
移动开发 小程序
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
763 0

热门文章

最新文章