文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vue vant-ui怎么使用van-uploader实现头像上传功能

2023-06-30 15:59

关注

本篇内容主要讲解“Vue vant-ui怎么使用van-uploader实现头像上传功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue vant-ui怎么使用van-uploader实现头像上传功能”吧!

效果图:

Vue vant-ui怎么使用van-uploader实现头像上传功能

Vue vant-ui怎么使用van-uploader实现头像上传功能

项目中是使用有赞vant-ui框架实现的头像上传替换功能

代码布局结构: 

<van-row class="sendInfo">        <van-col span="24" class="flex colorf topInfo p20">          <!--左边头像部分-->          <van-uploader :after-read="afterCard" :before-read="beforeRead"  accept="image/*" class="arrart"              :max-size="10240 * 1024" @oversize="onOversize">                            <img class="arrart"                :src=" centerInfo.iconUrl ? $baseImgUrl + centerInfo.iconUrl : require('../../assets/img/touciang.png')" />              <!-- <van-tag type="danger" class="vip" size="medium">VIP</van-tag> -->              <div class="personCompany">{{loginType==0?"个人用户":"企业用户"}}</div>          </van-uploader>           <!--右边部分-->          <div class="ml30">            <div class="flex rightVip">                            <span class="fontSize36 color0 mt20 van-ellipsis">郝先生</span>              <img :src="vipImg" width="46" height="20" class="mt20"  v-show="centerInfo.memberLevel==1" />            </div>            <div class="flex mt30">              <van-icon class="editIcon vmd mr10" color="#999" name="edit" />              <div class="fontSize30 color9 personInfo van-multi-ellipsis--l2">                优质船主              </div>            </div>          </div>        </van-col></van-row>

样式:

.flex {  display: flex;  width: 100%;}.topInfo {  align-items: center;  background-color: #fff;  // border-radius: 24px;}.arrart {  width: 128px;  height: 128px;  border-radius: 50%;}.personCompany {  position: absolute;  top: 100px;  left: 0px;  font-size: 0.4rem;  width: 128px;  height: 40px;  text-align: center;  background: #333440;  border-radius: 50px;  color: #ffdd99;  // padding:0px 6px;  line-height: 40px;}.rightVip {  width: 552px;  align-items: center;}

主要方法:这里用到了封装的图片压缩封装之后再去上传图片this.$imgUpload.imgZip()

//定义存储对象centerInfo: {},
// 限制上传大小图片    onOversize(file) {      this.$toast("文件大小不能超过 10M");    },    // 上传之前的图片验证    beforeRead(file) {      if (this.$utils.isImage(file.name)) {        return true;      } else {        this.$toast.fail("请上传图片格式");      }    },    // 头像上传  文件上传完毕后会触发 after-read 回调函数,获取到对应的 file 对象。    afterCard(file) {       this.$imgUpload.imgZip(file).then(resData => {        const formData = new FormData();        formData.append("file", resData);         // 请求接口上传图片到服务器        uploadImg(formData).then(res => {           if (res.code == 200) {            this.centerInfo.iconUrl = res.data;            let params = {              iconUrl: res.data,              id: this.id,              loginType: this.loginType            };            updateMineIconUrl(params)              .then(resImg => {                if (resImg.code == 200) {                  this.$toast("头像修改成功");                } else {                  this.$toast(res.msg);                }              })              .catch(error => {});          } else {            this.$toast(res.msg);          }        });      });    },

关于图片压缩方法、拍照上传的图片被旋转 90 度问题解决方法 后期会更新上去

Uploader 在部分安卓机型上无法上传图片?

Uploader 采用了 HTML 原生的 <input type="file /> 标签进行上传,能否上传取决于当前系统和浏览器的兼容性。当遇到无法上传的问题时,一般有以下几种情况:

扩展知识点:安卓10访问手机相册 有读写权限但是还是访问不到问题解决方案

安卓10访问手机相册 有读写权限但是还是访问不到问题解决方案

原因 安卓10 或者是打包target版本大于等于29的时候。就算有读写sd卡权限,谷歌依旧有限制。

解决方案1:

把target版本调整到 29以下

解决方案2:

修改androidmanifest.xml文件 在 <application 标签里再添加一个属性
android:requestLegacyExternalStorage=“true”

至于为什么target : 29以下可以呢 是因为谷歌默认29以下的 这个属性自动为true
到29开始就要手动填。 坑爹的谷歌!!!

到此,相信大家对“Vue vant-ui怎么使用van-uploader实现头像上传功能”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯