uniapp2023年微信小程序头像+昵称分别获取

1、DOM

javascript 复制代码
<view class="m-user">
	<view class="user-info">
		<!--头像 GO-->
		<button class="avatar avatar-wrapper" open-type="chooseAvatar" @chooseavatar="onChooseAvatar"
			slot="right">
			<image mode="aspectFill" src="默认的空图" v-if="!userinfo.avatar"></image>
			<image mode="aspectFill" :src="userinfo.avatar" v-else></image>
		</button>
		<!--昵称  GO-->
		<view class="nickname">
			<view class="tit" v-if="userinfo.nickname">
				<input  type="nickname" style="font-size:28rpx;flex: 1;" placeholder="请输入昵称"
					v-model="userinfo.nickname" @blur="getNickname" />
				<view class="font-24 mt40">
					{{userinfo.username}}
				</view>
			</view>
			<view class="tit" v-else>
				<text class="auth-login" @click="$zeropo.to(`/pages/users/login`)">授权登录</text>
			</view>
		</view>
	</view>
</view>

3、JS

javascript 复制代码
data() {
	return {
		HTTP_URL: this.$HTTP_URL,//服务器域名,按自己的项目修改
		userinfo: {
			nickname: '',//昵称
			username: '',//微信授权的字符
			avatar: '',//头像
		},
	}
},
/*methods*/
// 获取头像
onChooseAvatar(e) {
	let token = uni.getStorageSync('token')
	uni.showLoading()
	uni.uploadFile({
		url: this.HTTP_URL + '/common/upload',//上传接口,按自己的项目修改
		header: {
			token: token
		},
		filePath: e.detail.avatarUrl,
		name: 'file',
		success: (res) => {
			const r = JSON.parse(res.data);
			this.$api.post({
				url: '/user/profile',//更新用户信息的接口,按自己的项目修改
				data: {
					avatar: this.HTTP_URL + r.data.fileName,
				},
				success: re => {
					setTimeout(function() {
						uni.showToast({
							title: "设置成功"
						})
						uni.hideLoading()
					}, 1000)
					uni.stopPullDownRefresh();
				},
				fail: err => {

				},
			});

		},
		fail: (e) => {
			console.log('e', e)
		}
	});

},
// 获取昵称
getNickname(e) {
	this.nickname = e.detail.value
	this.$api.post({
		url: '/user/profile',更新用户信息的接口,按自己的项目修改
		data: {
			nickname: this.nickname,
		},
		success: re => {
			setTimeout(function() {
				uni.showToast({
					title: "设置成功"
				})
				uni.hideLoading()
			}, 1000)
			uni.stopPullDownRefresh();
			this.getUserinfo();//刷新用户信息,没写这个方法,按自己的项目修改,如果是表单页面则去掉
		},
		fail: err => {
			console.log('e', err)
		},
	});
},

3、CSS

css 复制代码
.m-user {
	height: 150rpx;
	padding: 30rpx 30rpx 0;
	border-bottom: 1rpx solid #f7f7f7;
	.user-info {
		display: flex;
		align-items: center;
		justify-content: space-between;
		.avatar {
			width: 130rpx;
			width: 130rpx;
			border: 0;
			background: none;
			padding: 0;
			margin: 0;
			line-height: 0;

			image {
				width: 130rpx;
				height: 130rpx;
				border-radius: 10rpx;
				overflow: hidden;
			}
		}

		.nickname {
			width: 550rpx;
			height: 130rpx;
			text-align: left;
			float: left;
			.tit {
				font-size: 30rpx;
				width: 100%;
				color: #1d363a;
				float: left;
				.auth-login {
					width: 140rpx;
					height: 50rpx;
					font-size: 26rpx;
					background: #fffae7;
					float: right;
					line-height: 50rpx;
					border-radius: 25rpx;
					text-align: center;
					color: #fecf5d;
				}

			}

		}

	}

}

3、效果图


4、发布申请隐私后,返回结果

发布申请隐私后,返回头像结果!

发布申请隐私后,返回头像结果!

发布申请隐私后,返回头像结果!

相关推荐
丁总学Java1 小时前
微信小程序,点击bindtap事件后,没有跳转到详情页,有可能是app.json中没有正确配置页面路径
微信小程序·小程序·json
说私域2 小时前
基于开源 AI 智能名片、S2B2C 商城小程序的用户获取成本优化分析
人工智能·小程序
mosen8682 小时前
Uniapp去除顶部导航栏-小程序、H5、APP适用
vue.js·微信小程序·小程序·uni-app·uniapp
qq22951165023 小时前
微信小程序的汽车维修预约管理系统
微信小程序·小程序·汽车
尚梦10 小时前
uni-app 封装刘海状态栏(适用小程序, h5, 头条小程序)
前端·小程序·uni-app
小飞哥liac13 小时前
微信小程序的组件
微信小程序
stormjun14 小时前
Java基于微信小程序的私家车位共享系统(附源码,文档)
java·微信小程序·共享停车位·私家车共享停车位小程序·停车位共享
paopaokaka_luck15 小时前
基于Spring Boot+Vue的助农销售平台(协同过滤算法、限流算法、支付宝沙盒支付、实时聊天、图形化分析)
java·spring boot·小程序·毕业设计·mybatis·1024程序员节
Bessie23417 小时前
微信小程序eval无法使用的替代方案
微信小程序·小程序·uni-app
shenweihong17 小时前
javascript实现md5算法(支持微信小程序),可分多次计算
javascript·算法·微信小程序