思路:
1.使用微信的 open-type="getUserInfo"
获取用户信息,将用户信息保存到userinfoDetails对象中去。
<button v-else type="primary" class="reserve-btn" open-type="getUserInfo" @getuserinfo="getuserinfo">预约挂号</button>
2.使用 uni.login() 获取code,并且把code传给后台,后台会返回openid
3.使用vuex和本地缓存保存相关状态值
备注vuex和本地缓存的区别:
vuex是响应式更新,页面不刷新数据也会实时更新,但是页面一刷新,数据可能会失效
本地缓存不会响应式更新,但是一刷新本地缓存就会更新。所以二者结合使用,前端小白不知道这个做法是否科学,
我把调用登录注册的方法封装到公共方法里
代码如下
import store from '@/store' const app = { apiUrl: 'https://hoxxxxxxxxop.com/', //请求的地址 _getuserinfo(res,ppid) { var that = this var userinfoDetails = {} userinfoDetails = res.detail.userInfo uni.getUserInfo({ provider: 'weixin', success: function () { uni.login({ success:function(res){ uni.showLoading({ title: '登陆中...', mask: false }); uni.request({ url: that.apiUrl + 'small/id"headimgurl")); userinfoDetails = JSON.parse(JSON.stringify(userinfoDetails).replace(/gender/g, "sex")); userinfoDetails = JSON.parse(JSON.stringify(userinfoDetails).replace(/nickName/g, "nickname")); delete userinfoDetails.language; userinfoDetails.ppid = ppid || '' console.log(userinfoDetails) uni.setStorageSync('userinfoDetails',userinfoDetails) } if(res.data.status == 0) { that.sendInfo(userinfoDetails) // 用户还没注册过需调用此方法 console.log('我还没有注册') } else { uni.showToast({ title: '登录成功', icon: 'success', duration: 2000 }) store.commit('login', res.data) // vuex的方法,存openid,userinfo,和更改isloginstatus状态值 uni.setStorageSync('StorageloginStatus',true) // 补充本地存储 localStorage解决vuex刷新数据不保留 uni.setStorageSync('Storageopenid',res.data.openid) uni.setStorageSync('Storageuserinfo',res.data.userinfo) } if (res.data.status == 0 && res.data.userinfo == 0) { uni.showToast({ title: '登录失败', duration: 2000 }) } } }) } }) } }); }, sendInfo(userinfoDetails) { var that = this uni.request({ url: this.apiUrl + 'sm/vip', //注册接口 data: userinfoDetails, method: 'POST', success: (res) => { if(res.data.userinfo == 1) { uni.hideLoading() uni.showToast({ title: '注册成功', icon: 'success', duration: 2000 }) store.commit('login', res.data) // vuex的方法,存openid,userinfo,和更改isloginstatus状态值 uni.setStorageSync('StorageloginStatus',true) uni.setStorageSync('Storageopenid',res.data.openid) uni.setStorageSync('Storageuserinfo',res.data.userinfo) } else { uni.hideLoading() uni.showToast({ title: res.data.msg, duration: 2000 }) } } }) } } export default app;
在index.vue调用
用Vuex中的isloginStatus和缓存中的StorageloginStatus来控制是否显示登录的按钮
<button v-if="isloginStatus || StorageloginStatus" type="primary" class="reserve-btn" @click="goreserve">跳转</button> <button v-else type="primary" class="reserve-btn" open-type="getUserInfo" @getuserinfo="getuserinfo">登录</button> import app from '../../common/config.js' export default { data() { return { ppid: "", StorageloginStatus: false } }, computed: mapState({ isloginStatus: state => state.isloginStatus, }), onLoad(option) { this.ppid = this.scene_decode(option.scene).ppid //封装的scene_decode() 方法 this.StorageloginStatus = uni.getStorageSync('StorageloginStatus') }, methods: { // 获取用户信息 getuserinfo(res) { app._getuserinfo(res,this.ppid) // 封装好的方法 res是微信返回的用户信息,ppid是二维码携带的参数 }, // 当注册或者登录成功 显示路由按钮 goreserve() { console.log('去挂号了') } } }
vuex
import Vue from 'vue' import Vuex from 'vuex'
Vue.use(Vuex)
const store = new Vuex.Store({ state: { isloginStatus: false, userinfo: "", // 状态值 openid: "", userinfoDetails: {} ,// 头像姓名城市等。。。 ppid: "" }, mutations: { login(state,res) { state.isloginStatus = true, state.userinfo = res.userinfo, // 如果userinfo==1 --->已登录 state.openid = res.openid }, saveUserinfoDetails(state,res) { state.userinfoDetails = res }, savePPid(state,id) { stage.ppid = id // 存ppid } }, }) export default store
总结
以上所述是小编给大家介绍的vue中uni-app 实现小程序登录注册功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 仙境传说新启航一区是哪个区 仙境传说一区服务器介绍
- 叶倩文2014《影视金曲》LPCD45【WAV+CUE】
- 张国荣1996-哥哥的前半生[华星]2CD[WAV]
- 银霞.1981-《泥泞中的小花·期待》台湾复刻版[WAV+CUE]
- PS掌机游玩《宇宙机器人》体验测试 玩家:这游戏就得用便携模式玩!
- 《黑神话:悟空》角色游戏内形象与86版西游记对比:这版本太经典了
- 《尘白禁区》凯茜娅泳装视频:碧海之中摇曳的少女们
- 林珊如.1997-神秘的感觉【鸿谷唱片】【WAV+CUE】
- 群星.1991-8大巨星展魅力【新丽声】【WAV+CUE】
- 群星.2021-流金岁月电视剧原声带【仁溪音乐】【FLAC分轨】
- 魔兽世界地心之战踏风武僧用什么饰品 地心之战踏风武僧饰品推荐
- 仙境传说新启航新手职业怎么选 仙境传说新手职业推荐
- 魔兽世界地心之战酒仙武僧用什么饰品 地心之战酒仙武僧饰品推荐
- 王菲.2001-《菲经典DSD》引进版[WAV+CUE]
- 【雨果唱版】民歌对唱《红英与唐彪LPCD45》2007[WAV+CUE]