小程序最新获取用户头像昵称

news2025/7/29 0:33:53

目录

一、前言

二、遇到的问题

三、效果页面

四、代码实现


记录:

一、前言

 昨天打开编辑器后,发现小程序用户的头像与昵称都给变默认了,就去网上搜了一下:

小程序用户头像昵称获取规则调整公告 | 微信开放社区   

我去,居然给改了,之前一直按照接口的方法来写的,还有很多页面要用到用户头像昵称信息。

没办法,只有去改了...... 

二、遇到的问题

文档:头像昵称填写 | 微信开放文档

变成填写这样了:直接用文档给的代码的话,开始用的很爽,但当我复制到开发者工具上后,发现了一些问题:

  •  原代码样式用的 WeUI,我没有用。

  • input 直接填写微信名时,获取不到昵称信息。

  • 获取的头像地址是临时的!

这样搞就有点麻烦了,最后用 form 来收集头像昵称信息,对于头像地址的临时性,存在缓存好像可以用,当然最好的办法就是直接将用户头像、昵称传的自己的服务器上。

三、效果页面

效果页面:

四、代码实现

 代码:

  • WXML
<view class="t1">
  <text>欢迎~~</text>
  <view class="t2">
    <text>点击完善头像、昵称信息</text>
  </view>
</view>


<form bindsubmit="login">

  <button class="avatar-wrapper"  plain="true"  open-type="chooseAvatar" name='avatarUrl' bind:chooseavatar="onChooseAvatar">
    <image class="avatar" src="{{avatarUrl}}"></image>
  </button>
  <view class="ttt">
    <text class="nichen">昵称:</text>
    <input type="nickname" name='nickName' class="weui-input" placeholder="请输入昵称" />
  </view>

  <button form-type="submit" class="sure">点击确认</button>

</form>


<view class="statement">
  <checkbox bindtap="select" value="cb" />
  <text bindtap="gotoBook">已阅:用户条款&&隐私策略</text>
</view>
  •  WXSS
 
/* 去掉button边框 */
.avatar-wrapper {
  border: none !important;
  margin-top: 40rpx;
}    

.avatar-wrapper {
  background-color: #ffffff;

}
.weui-input {
  color: #ffffff;
  margin-left: 60rpx;
  text-align: left;

}

.avatar {
  width: 100rpx;
  height: 100rpx;
  display: flex;
  margin: 0 auto;

}
.ttt {
  margin: 20rpx;

}

.nichen {
  float: left;
  color: white;
  font-weight: bold;
  margin-right: 40rpx;
}

.t1 {
  margin-left: 20rpx;
  margin-top: 450rpx;
  font-weight: bold;
  font-size: 42rpx;
  margin-bottom: 30rpx;
  color: white;
}
.t2 {
  margin-top: 20rpx;
}
.t2 text {
  opacity: 0.8;
  font-weight: lighter;
  color: white;
  font-size: 30rpx;
}

page {
  background-image: url('https://636c-cloud1-7g1a0u3je2bf6f8d-1314056523.tcb.qcloud.la/%E7%A7%BB%E9%80%9A%E5%85%A8%E6%99%AF%E5%9B%BE/pexels-photo-13717143.jpeg?sign=492505ce1f5432ed0164a8eaf41c656d&t=1668507676') ;
  background-size: cover;
}

.sure {
  margin-top: 60rpx;
  width: 70%;
}

.statement {
  color: #ffffff;
  text-align: center;
  margin-top: 600rpx;
  font-size: 26rpx;
  align-content: center;
}

.statement text:nth-child(2) {
  margin-left: 15rpx;
}
  • JSON
{
  "usingComponents": {},
  "navigationStyle": "custom",
  "enablePullDownRefresh": false
}
  • JS
const defaultAvatarUrl = 'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    avatarUrl: defaultAvatarUrl,
    check: false,
  },

  // 选择头像 
  onChooseAvatar(e) {
    const {
      avatarUrl
    } = e.detail
    this.setData({
      avatarUrl,
    })
  },
  // 跳转到免责声明
  gotoBook() {
    wx.navigateTo({
      url: '/pages/agreementS/agreementS',
    })
  },
  // 勾选阅读 协议
  select() {
    this.setData({
      check: !this.data.check,
    })
    console.log(this.data.check)
  },
  // 登录   确认信息修改, 跳转到我的页面
  login(e) {
    if (this.data.check == false) {
      wx.showToast({
        title: '请勾选已阅读用户条款',
        icon: "none"
      })
      return;
    } else if (this.data.avatarUrl == defaultAvatarUrl) {
      wx.showToast({
        title: '请点击头像进行修改',
        icon: "none"
      })
      return;
    } else if (e.detail.value.nickName == null || e.detail.value.nickName == '') {
      wx.showToast({
        title: '请修改昵称',
        icon: "none"
      })
      return;
    }

    console.log('提交的数据:', e.detail.value.nickName)
    let avatarUrl = {
      avatarUrl: this.data.avatarUrl,
      nickName: e.detail.value.nickName
    }
    wx.setStorageSync('key', avatarUrl)

    wx.reLaunch({
      url: '/pages/my/my',
    })

  },

})

这里我是把用户的头像昵称信息给缓存下来的,直接src用头像地址会失效,但我缓存的过了一个小时都还能用,就没有传到服务器,主要是因为我其他页面都是直接用的缓存来展示用户的头像与昵称的,偷个懒咯。后面不行的话,我再来改改~~~

 拜拜~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/16339.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring6整合JUnit5

十七、Spring6整合JUnit5 17.1 Spring对JUnit4的支持 准备工作&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instanc…

[附源码]java毕业设计暖暖猫窝系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Linux之软连接和硬连接的用法和区别【详细!!!】

目录软连接创建一个软连接删除软连接硬链接创建硬链接删除硬链接硬链接和软连接之间的区别软连接 创建一个软连接 ln -s [源文件或目录] [软连接名称] 例子&#xff1a; 在/home目录下创建一个软连接linkToRoot 链接到/root目录 删除软连接 rm -f /linkToRoot例子&#x…

供应CAS:73342-16-2,N3-PEG-OH,Azide-PEG-Hydroxy,叠氮-聚乙二醇-羟基

一&#xff1a;产品描述 1、名称 英文&#xff1a;N3-PEG-OH&#xff0c;Azide-PEG-Hydroxy 中文&#xff1a;叠氮-聚乙二醇-羟基 2、CAS编号&#xff1a;73342-16-2 3、所属分类&#xff1a;Azide PEG Hydroxyl PEG 4、分子量&#xff1a;可定制&#xff0c;叠氮-PEG 34…

[附源码]java毕业设计某公司酬薪管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

无需重启应用,动态采集任意点位日志

作者&#xff1a; 屿山 现实系统往往有着较高的复杂度&#xff0c;我们借助 Trace、Log、Metric 三驾马车使我们的系统具备了一定的可观测性&#xff0c;但观测位置和信息往往是固定的&#xff0c;而我们所遇到的问题常常是意料之外的&#xff0c;这就导致我们能够定位问题的范…

BLE学习(1):蓝牙协议栈的介绍

蓝牙官方(The Bluetooth Special Interest Group)定义了低功耗蓝牙(Bluetooth low energy,即LE)和基础/增强速率蓝牙(Bluetooth basic rate/enhanced data rate ,即BR/EDR)两种技术的协议栈。这两种协议栈可以单独使用&#xff0c;也可以同时使用&#xff0c;如下图所示&#x…

泛型「generic」讲解

标题1. 泛型语法1.1 泛型的引出1.2 泛型介绍1.3 泛型语法1.4 泛型使用细节1.5 练习题2.自定义泛型2.1自定义泛型-类2.2自定义泛型-接口2.3自定义泛型-方法2.4练习题3.范型继承和通配符3.1JUnit单元测试框架3.2练习题1. 泛型语法 1.1 泛型的引出 传统方法不能对加入到集合中的…

Docker部署ELK

Docker部署ELK安装包下载1、安装docker2、安装docker compose3、使用docker加载离线镜像4、上传yml文件并初始化密码5、造数据&#xff0c;看采集结果安装包下载 链接:https://pan.baidu.com/s/1LOHyhTHm3-30v6wAfYLTAg 提取码:5uno 1、安装docker &#xff08;1&#xff09…

Python新手的福音,涵盖20+种初学者必练项目!

前言 对学Python的新手同学来说&#xff0c;最最最想要的干货是什么&#xff1f;是大量可以练手的项目啊。俗话说&#xff0c;三天不练手生&#xff0c;三天不念口生。#技术派的书架# &#xff08;文末送读者福利&#xff09; 在某乎上有一个关于"Python的练手项目”的问…

【线程】线程同步

目录 一、信号量 1.函数 2.使用 二、读写锁 1.函数 2.使用 三、互斥锁 1.函数 2.使用 四、条件变量 1.函数 2.使用 前言 线程同步的实现方法&#xff1a;信号量、互斥锁、条件变量、读写锁。 下面就对着四种方法进行展开描述 一、信号量 与进程间通信的信号量类似&a…

JNPF3.4.5大版本正式上线啦!

千呼万唤始出来&#xff0c;时隔近四个月&#xff0c;引迈信息终于再度推出新版本与大家见面了&#xff0c;此次推出的3.4.5大版本&#xff0c;可谓是吊足了大家的胃口。 本次大更新为用户带来的是高效率、高可用性、低成本、快速部署、易于扩展的快速开发平台的使用体验。本次…

【ASM】字节码操作 工具类与常用类 TraceClassVisitor 介绍

文章目录 1.概述2. TraceClassVisitor2.1 class info2.2 字段信息2.3 constructors2.4 methods3.如何使用TraceClassVisitor3.1 生成新的类3.2 修改已有的类3.3 打印ASM信息4.总结感谢第一个订阅字节码的人,感谢老铁支持 adminhjy 1.概述 在上一篇文章:

拓展卡尔曼滤波(Kalman)附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;修心和技术同步精进&#xff0c;matlab项目合作可私信。 &#x1f34e;个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知。 更多Matlab仿真内容点击&#x1f447; 智能优化算法 …

分享5个良心好用的PC软件,免费无广告

今天再次推荐5个良心好用的Windows神级软件&#xff0c;每一个都是完全免费&#xff0c;堪称神器&#xff0c;让你打开新世界的大门。 1.数据恢复工具——EaseUS Data EaseUS Data Recovery Wizard是一款简单易用的数据恢复工具&#xff0c;给用户提供了三种恢复模式&#xf…

docker部署ES及kibana整个流程

对于ES小白&#xff0c;第一次安装ES走了很多弯路&#xff0c;下面记录自己本地安装elasticsearch的整个过程&#xff0c;我觉得小白如果按照我的流程走&#xff0c;大部分应该可以安装并运行成功。下面是整个步骤&#xff1a; 一、部署ES 拉取镜像 docker pull docker.elast…

胞外囊泡代谢组学—前列腺癌代谢变化研究的新策略

小小身体蕴含大大能量&#xff01;前列腺癌非侵入性的诊断和监测的新方式——胞外囊泡&#xff08;外泌体&#xff09;代谢组学&#xff01;目前&#xff0c;胞外囊泡/外泌体作为非侵入性的癌生物标志物已成为新的研究热点。百趣代谢组学文献分享&#xff0c;芬兰赫尔辛基大学学…

避免项目资源管理陷阱,8Manage帮你支招!

项目资源管理主要是对项目所需的人力、材料、机械、技术、资源等资源进行计划、组织、指挥、协调和控制。众所周知&#xff0c;项目推进需要资源支撑&#xff0c;一旦资源不足&#xff0c;项目的进度和质量都会受到影响。而在项目管理活动中&#xff0c;做好资源管理并不容易&a…

SORT追踪

卡尔曼滤波 卡尔曼滤波用当前时刻运动变量去预测下一时刻的运动变量&#xff0c;检测器第一次的检测结果用来初始化卡尔曼滤波的运动变量&#xff0c;后续的结果作为更新。在信号处理中卡尔曼滤波是去除噪声的一个算法&#xff0c;作用是使用信号更加的准确。在SORT中的&#x…

MySQL常用语句汇总

一、背景 日常测试开发工作中会用到各类SQL语句&#xff0c;很多时候都是想用的时候才发现语句细节记不清楚了&#xff0c;临时网上搜索SQL语法&#xff0c;挺费时费力的&#xff0c;语法还不一定是对的。因此汇总整理了一下MySQL最常用的各类语句&#xff0c;以后就不用再到处…