2301_76146661 2023-04-29 17:37 采纳率: 80%
浏览 21
已结题

如何在ABC三个页面之间连续传参?

unapp中写小程序需要ABC三个页面动态传值,现在已经从A页面传参name和src到了B页面,需要把以上两个原封不动传到C页面,但是不能添加事件,因为页面其他位置已经有了点击事件了,此处不能添加点击事件,只能原封不动传到C页面,请教该怎么写呢?谢谢

<image class="img" :src="src" mode=""></image>
            <view class="">
                {{name}}->
            </view>


  • 写回答

2条回答 默认 最新

  • 疯狂的豆包 2023-04-29 20:04
    关注

    可以使用小程序提供的页面栈来实现原封不动地传值到C页面,具体步骤如下:

    1. 在B页面的onLoad函数中获取A页面传递过来的参数,并将其存储到B页面的data中。

    2. 在B页面的onUnload函数中将参数存储到页面栈中,以便在C页面中获取。

    3. 在C页面的onLoad函数中从页面栈中获取参数,并将其存储到C页面的data中。

    下面是示例代码:

    // B页面
    Page({
      onLoad: function(options) {
        // 获取A页面传递过来的参数
        const { name, src } = options;
        // 存储参数到B页面的data中
        this.setData({
          name,
          src
        });
      },
      onUnload: function() {
        // 将参数存储到页面栈中
        const pages = getCurrentPages();
        const prevPage = pages[pages.length - 2];
        prevPage.setData({
          name: this.data.name,
          src: this.data.src
        });
      }
    });
    
    // C页面
    Page({
      onLoad: function() {
        // 从页面栈中获取参数
        const pages = getCurrentPages();
        const prevPage = pages[pages.length - 2];
        const { name, src } = prevPage.data;
        // 存储参数到C页面的data中
        this.setData({
          name,
          src
        });
      }
    });
    

    在C页面中,可以直接使用data中存储的name和src参数,例如:

    <image class="img" :src="src" mode=""></image>
    <view class="">{{name}}-></view>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月8日
  • 已采纳回答 4月30日
  • 创建了问题 4月29日

悬赏问题

  • ¥15 校内二手商品转让网站
  • ¥20 高德地图聚合图层MarkerCluster聚合多个点,但是ClusterData只有其中部分数据,原因应该是有经纬度重合的地方点,现在我想让ClusterData显示所有点的信息,如何实现?
  • ¥100 求Web版SPC控制图程序包调式
  • ¥20 指导如何跑通以下两个Github代码
  • ¥15 大家知道这个后备文件怎么删吗,为啥这些文件我只看到一份,没有后备呀
  • ¥15 C++为什么这个代码没报错运行不出来啊
  • ¥15 一道ban了很多东西的pyjail题
  • ¥15 关于#r语言#的问题:如何将生成的四幅图排在一起,且对变量的赋值进行更改,让组合的图漂亮、美观@(相关搜索:森林图)
  • ¥15 C++识别堆叠物体异常
  • ¥15 微软硬件驱动认证账号申请