uniapp 小程序,登录上传头像昵称页面处理步骤

登录上传头像 成功前阻塞 处理成功后才跳转回 游戏页面 为了能看见最新上传的头像显示,处理方式是 重新封装base64处理方法为promise 这样可以用await等待,请求后台的方法也等待,等待处理完成后调用跳转页面方法,同时信息上传完成后要跳转的页面的初始钩子事件由onload改为onshow,这个钩子中包含获取缓存中useinfo的处理, 这样每次出来再切换进来都会重新获取新的用户信息。ps 保存请求回来的用户信息并放入缓存是 登录方法login中封装好的

javascript 复制代码
	// 重新封装base64处理方法为promise 这样可以用await等待
	const readFileAsync = (filePath) => {
	  return new Promise((resolve, reject) => {
	    uni.getFileSystemManager().readFile({
	      filePath,
	      encoding: 'base64',
	      success: (res) => resolve(res),
	      fail: (err) => reject(err)
	    });
	  });
	};
	const upLoad = async (isSuccessClose) => {
		const r = await readFileAsync(avatarUrl.value, 'base64');
		console.log('base64转换完成的结果',r.data);
		const avatarUrl_base64 = 'data:image/jpeg;base64,' + r.data
		console.log('avatarUrl_base64 转换完成 ', avatarUrl_base64)
		const res = await myUtils.requestAwait('user/updateUserDetail', {
			nickName: nickName.value,
			avatarUrl: avatarUrl_base64,
			openid: userInfo.value.openid
		})
		if(!isSuccessClose){
			return
		}
		
		console.log('头像上传完成 ', res)
		uni.showToast({
			title: '保存成功',
			icon: 'none', //success 等
			duration: 1000
		});
		console.log('头像后登录')
		const lr =await myUtils.login()
		console.log('登录完成后跳转')
		to1Tab('grid')
		console.log('登录完成跳转完成')
		console.log(' 后加的上传结果恢复  ',res)
		
	}

成功后跳转的页面处理

javascript 复制代码
	onShow(()=>{	
		makeValArr()
		userInfo.value = uni.getStorageSync('userInfo');
		console.log('新 获取完成112 ', userInfo.value.avatarUrl)
	})
相关推荐
dcloud_jibinbin37 分钟前
【uniapp】小程序体积优化,分包异步化
前端·vue.js·webpack·性能优化·微信小程序·uni-app
2501_916008891 小时前
金融类 App 加密加固方法,多工具组合的工程化实践(金融级别/IPA 加固/无源码落地/Ipa Guard + 流水线)
android·ios·金融·小程序·uni-app·iphone·webview
2501_915921432 小时前
Fastlane 结合 开心上架(Appuploader)命令行版本实现跨平台上传发布 iOS App 免 Mac 自动化上架实战全解析
android·macos·ios·小程序·uni-app·自动化·iphone
游戏开发爱好者83 小时前
iOS 上架要求全解析,App Store 审核标准、开发者准备事项与开心上架(Appuploader)跨平台免 Mac 实战指南
android·macos·ios·小程序·uni-app·iphone·webview
00后程序员张4 小时前
混淆 iOS 类名与变量名的实战指南,多工具组合把混淆做成工程能力(混淆 iOS 类名变量名/IPA 成品混淆Ipa/Guard CLI 实操)
android·ios·小程序·https·uni-app·iphone·webview
码起来呗7 小时前
基于Spring Boot的乡村拼车小程序的设计与实现-项目分享
spring boot·后端·小程序
2501_916007478 小时前
iOS文件管理工具深度剖析,从系统沙盒到跨平台文件操作的多工具协同实践
android·macos·ios·小程序·uni-app·cocoa·iphone
shykevin8 小时前
uni-app x开发商城系统,扩展组件uni-ui实现底部商品导航
uni-app
wapchief8 小时前
微信小程序camera相机帧转图片base64
微信小程序·小程序
QuantumLeap丶8 小时前
《uni-app跨平台开发完全指南》- 05 - 基础组件使用
vue.js·微信小程序·uni-app