解释代码 onShow() { var user = app.globalData.vipInfo; if (user && user.phone) { console.log("user.viptime",user.viptime) let shengyu = user.viptime - new Date().getTime() console.log("会员剩余时间", shengyu) this.setData({ user: user, shengyu, vipTimeStr: app._getCurrentTime(user.viptime) }) } else { wx.showModal({ confirmText: "去注册", content: "先去注册为用户,才可以充值会员", cancelColor: '取消', success: res => { if (res.confirm) { wx.navigateTo({ url: '/pages/change/change', }) } } }) } },
时间: 2023-12-06 17:39:53 浏览: 81
这段代码是在小程序中的一个页面展示时执行的函数。首先,它从全局变量 app.globalData 中获取了用户信息 user,如果用户信息中存在手机号码 user.phone,那么就计算该用户的会员剩余时间 shengyu,并将用户信息、剩余时间和一个格式化后的会员过期时间字符串 vipTimeStr 存储到当前页面的数据对象 this.data 中。
如果用户信息中不存在手机号码,那么就弹出一个模态对话框,提示用户需要先注册成为用户才能充值会员。如果用户点击确认按钮,那么就跳转到注册页面,否则就取消操作。
相关问题
解释这段代码onShow(options) { //微信用户信息 var userStor = wx.getStorageSync('user'); if (userStor && userStor.nickName) { console.log('本地获取微信用户信息', userStor) this.setData({ userInfo: userStor, }) } else { this.setData({ userInfo: null, }) } // 获取Java用户信息和会员信息 this.getVipInfo() }, // 获取Java用户信息和会员信息 getVipInfo() { let that=this wx.request({ url: app.globalData.baseUrl + '/user/getUserInfo', data: { openid: app.globalData.openid }, success: function (res) { console.log("个人中心Java后台返回的用户信息", res.data) if (res && res.data && res.data.data) { app._updateVipInfo(res.data.data) // java用户信息和会员信息 var user = app.globalData.vipInfo; if (user.viptime && user.viptime > 0) { let shengyu = user.viptime - new Date().getTime() console.log("会员剩余时间", shengyu) that.setData({ shengyu, vipTimeStr: app._getCurrentTime(user.viptime) }) } } } }) }, //获取微信用户信息 getUserProfile() { wx.getUserProfile({ desc: '用于完善会员资料', // 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写 success: (res) => { console.log("获取用户信息成功", res) let user = res.userInfo this.setData({ userInfo: user, }) wx.setStorageSync('user', user) }, fail: res => { console.log("获取用户信息失败", res) } }) },
这段代码是一个小程序页面的生命周期函数 `onShow()` 以及两个自定义函数 `getVipInfo()` 和 `getUserProfile()` 的实现。
在 `onShow()` 函数中,首先从本地存储中获取微信用户信息,如果存在则将用户信息设置到页面的 `userInfo` 数据中;否则将 `userInfo` 数据设置为 null。然后调用 `getVipInfo()` 函数,该函数通过发送网络请求获取 Java 后台返回的用户信息和会员信息,如果成功获取到,则将数据更新到全局变量 `vipInfo` 中,并从中获取会员剩余时间和有效期字符串,将这些数据设置到页面的数据中。
`getUserProfile()` 函数用于获取用户的微信信息,包括昵称、头像等。在获取成功后,将用户信息设置到页面的 `userInfo` 数据中,并将其存储到本地缓存中。
总的来说,这段代码主要实现了获取微信用户信息和 Java 后台的用户信息和会员信息,并将这些数据设置到页面的数据中。
解释代码const app = getApp() let moneyVip = 100 //一年会员扣多少钱 Page({ data: { viptime: 0, vipTimeStr: '' }, onShow() { var user = app.globalData.vipInfo; if (user && user.phone) { console.log("user.viptime",user.viptime) let shengyu = user.viptime - new Date().getTime() console.log("会员剩余时间", shengyu) this.setData({ user: user, shengyu, vipTimeStr: app._getCurrentTime(user.viptime) }) } else { wx.showModal({ confirmText: "去注册", content: "先去注册为用户,才可以充值会员", cancelColor: '取消', success: res => { if (res.confirm) { wx.navigateTo({ url: '/pages/change/change', }) } } }) } }, //充值会员 payVip(e) { let user = this.data.user let year = e.currentTarget.dataset.year if (moneyVip * year > user.money) { wx.showToast({ icon: "none", title: '余额不足', }) return } wx.showModal({ confirmText: "确认充值", content: "充值会员将扣除" + moneyVip * year + "元,确定充值吗", cancelColor: '取消', success: res => { if (res.confirm) { wx.request({ url: app.globalData.baseUrl + '/user/payVip', method: "POST", header: { "Content-Type": "application/x-www-form-urlencoded" }, data: { openid: user.openid, money: moneyVip * year, time: year * 31536000000 }, success(res) { if (res && res.data && res.data.data) { console.log("会员充值成功", res.data) wx.showToast({ title: '充值成功', })
这段代码是一个小程序页面的逻辑代码。主要实现的功能是用户充值会员,会员有效期为一年。具体解释如下:
1. const app = getApp(): 获取小程序实例对象。
2. let moneyVip = 100: 定义一个会员一年的价格。
3. Page({ ... }): 定义一个页面对象。
4. data: {...}: 给页面对象定义一个数据属性,包括 viptime(会员到期时间戳)、vipTimeStr(会员到期时间的格式化字符串)等。
5. onShow() {...}: 页面显示时调用的函数。首先获取全局变量中的用户信息,如果用户已经注册并且绑定了手机号码,则显示用户的会员信息,包括剩余时间以及到期时间的格式化字符串;否则提示用户先去注册。
6. payVip(e) {...}: 用户点击充值会员按钮时调用的函数。首先判断用户余额是否足够支付,如果不足则提示用户余额不足;否则弹出确认对话框,让用户确认支付。如果用户确认支付,则向服务器发送支付请求,同时更新用户的会员信息并提示充值成功。
需要注意的是,这段代码中可能存在安全隐患,比如没有对用户输入的年份进行验证等。如果在实际开发中使用,需要加强代码的安全性。
阅读全文