微信小程序,异步请求,回调函数中for循环结束后再赋值

原请求

wx.request({
    url: url,
    data:data,
    success: (res) => {
        let list = res.data
		 for(let i = 0; i < list.length; i++){
			wx.request({
				url: url,
				success: (res1) => {
					list[i].obj = res1.data
				},
				fail: err => reject(err)
			});
		 }
		 this.setData({
          list : list
        })
    },
    fail: err => reject(err)
});

修改后

wx.request({
    url: url,
    data:data,
    success: (res) => {
        let list = res.data;
        let promises = [];

        for (let i = 0; i < list.length; i++) {
            promises.push(new Promise((resolve, reject) => {
                wx.request({
                    url: url,
                    data:data,
                    success: (res1) => {
                        list[i].obj = res1.data;
                        resolve();
                    },
                    fail: err => reject(err)
                });
            }));
        }

        Promise.all(promises).then(() => {
            this.setData({
                list: list
            });
        }).catch(error => {
            console.error("An error occurred while fetching data:", error);
        });
    },
    fail: err => {
        console.error("An error occurred while fetching data:", err);
    }
});

### 开发知识付费微信小程序教程 #### 一、项目规划与需求分析 在启动开发之前,需明确项目的具体功能模块以及业务流程。这包括但不限于课程展示、购买机制、用户管理等内容[^1]。 #### 二、环境准备 确保本地计算机已安装Node.js和npm工具链;注册成为微信公众平台开发者账号,并创建好对应的小程序AppID用于后续配置文件填写[^2]。 #### 三、框架选择和技术栈确定 对于前端部分推荐采用WeUI库来构建页面样式,它是由腾讯官方团队维护的一套基于原生Web组件封装而成的设计体系,非常适合用来快速搭建美观大方又不失性能表现力的应用界面。而后端服务可以考虑使用Express.js配合MongoDB数据库实现数据存储及API接口提供等功能。 #### 四、核心功能实现 ##### 1. 用户认证授权 通过调用微信开放平台提供的OAuth2.0协议完成用户的登录鉴权操作,在此过程中会涉及到code换取session_key等逻辑处理过程。 ```javascript wx.login({ success (res) { if (res.code) { wx.request({ url: 'https://api.weixin.qq.com/sns/jscode2session', data: { appid: APP_ID, secret: SECRET_KEY, js_code: res.code, grant_type: 'authorization_code' }, success(res){ console.log('获取到的openid:', res.data.openid); } }) } else { console.error('登录失败!' + res.errMsg) } } }) ``` ##### 2. 商品列表渲染 利用WXML模板语法结合WXSS样式表定义商品卡片布局结构,再借助于`<block>`标签循环遍历后台返回的商品JSON数组对象填充至视图层显示出来。 ```html <!--index.wxml--> <view class="goods-list"> <block wx:for="{{goodList}}" wx:key="id"> <navigator url="/pages/detail/index?id={{item.id}}"> <image src="{{item.coverUrl}}"></image> <text>{{item.title}}</text> <price>¥{{item.price.toFixed(2)}}</price> </navigator> </block> </view> /* index.wxss */ .goods-list navigator{ display:flex; flex-direction:column; } ``` ##### 3. 支付集成 接入财付通JS-SDK按照官方文档指引完成订单创建、发起预支付请求直至最终回调通知整个交易闭环流程设计。 ```javascript // 创建订单函数 function createOrder(orderInfo, callback){ wx.request({ method:'POST', header:{'content-type':'application/json'}, url:'/create-order', // 后台接口地址 data:{ body:"测试商品", out_trade_no:new Date().getTime(), total_fee:Number.parseInt(orderInfo.totalPrice*100), spbill_create_ip:getIP(), // 获取客户端真实ip的方法自行补充 notify_url:'http://yourdomain.com/pay/notify',// 微信服务器异步通知url trade_type:'JSAPI', openid:orderInfo.userId }, success:(result)=>{ let prepayId=result.prepay_id; pay(prepayId,callback); // 调用支付方法传入prepayId参数继续执行下一步骤... } }); } // 发起支付函数 function pay(prePayId,callback){ wx.requestPayment({ timeStamp:'', nonceStr:'', package:`prepay_id=${prePayId}`, signType:'MD5', paySign:'', // 需要先计算签名才能赋值给这个字段 success(callback),fail(err)=>console.warn(`支付失败:${err}`) }); } ``` #### 五、部署上线前测试优化 针对不同网络环境下可能出现的问题进行全面排查修复工作,比如图片加载缓慢可尝试压缩资源体积或者启用CDN加速分发等方式提升用户体验满意度水平。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值