微信小程序 跳转界面,选择货物之后,返回上一页带参数并判断参数是否存在

需求

当刚进来时选择货物,跳转到选择货物界面进行货物选择,如果货物重复,不再新增货物,如果不存在,则新增
prevPage.setData()用于在页面之间传递数据。它将数据设置到上一个页面(即prevPage)的data对象中,然后可以在上一个页面中通过data属性访问该数据。这种方式适用于在页面之间传递少量数据。
wx.setStorage和wx.setStorageSync用于在本地存储中保存数据。它们可以将数据存储在微信小程序的本地缓存中,以便在小程序的不同页面中进行读取和使用。这种方式适用于需要在不同页面之间长期存储数据的情况。

选择货物


选择完毕之后

js 复制代码
// main.js
 /**
     * 上一个页面的初始数据
     */
    data: {
        addGoods: [],
        }
        
   /**
     * 生命周期函数--监听页面显示
     */
    onShow() {
        let that = this;
        // 选择了产品信息
        if (that.data.addGoods && that.data.goods.length == 0) {
            that.setData({
                goods: that.data.addGoods
            })
        } else if (that.data.addGoods.length > 0 && that.data.goods.length > 0) {
            for (let j = 0; j < that.data.addGoods.length; j++) {
                // 检查新数组中是否已经包含具有相同id的对象
                let existingElement = that.data.goods.find(item => item.id === that.data.addGoods[j].id);
                if (!existingElement) {
                    that.data.goods.push(that.data.addGoods[j]);
                }
            }
            that.setData({
                goods:that.data.goods
            })
        }
    },     
js 复制代码
   //child.js 在需要进行传值的地方进行setData
   
  let pages = getCurrentPages(); // 获取页面栈  好处在于 刷新比缓存及时
        let currPage = pages[pages.length - 1]; // 当前页面
        let prevPage = pages[pages.length - 2]; // 上一个页面
        prevPage.setData({
            // 要设置的值
            addGoods: arr
        })

注意:在使用setData()方法传递数据给父页面时,需要保证父页面已经加载完成,否则可能会出现数据传递不成功的情况。

相关推荐
Jiaberrr2 小时前
前端实战:使用JS和Canvas实现运算图形验证码(uniapp、微信小程序同样可用)
前端·javascript·vue.js·微信小程序·uni-app
h177113472053 小时前
单身狗的逆袭之路之开发相亲交友系统
微信小程序·小程序·交友·系统开发·回归算法
工业互联网专业4 小时前
毕业设计选题:基于springboot+vue+uniapp的驾校报名小程序
vue.js·spring boot·小程序·uni-app·毕业设计·源码·课程设计
李宥小哥5 小时前
微信小程序05-常用API下
微信小程序·小程序
李宥小哥5 小时前
微信小程序06-综合项目点餐系统
微信小程序·小程序·notepad++
说私域9 小时前
构建有温度的用户关系:开源 AI 智能名片、链动 2+1 模式与 S2B2C 商城小程序的作用
人工智能·小程序
说私域9 小时前
社交电商中“信任”基础与“链动 2+1 模式 O2O 商城小程序”的价值探索
小程序
I592O9297839 小时前
大健康裂变分销小程序开发
小程序
前端-文龙刚9 小时前
小程序给对象赋值(双向绑定)方法之一
服务器·小程序·apache
fakaifa12 小时前
八戒农场小程序V2最新源码
小程序·uni-app·php·生活·开源软件