vue.js 图片上传并预览及图片更换功能的实现代码
作者:新叶之扉之丹儿 时间:2024-05-09 15:23:47
这里讲解是图片上传和图片预览。主要是围绕我们常用功能的列子做讲解 ,并且没有格外引入其他js 所以你复制过去做简单修改便可以看到效果
效果图:
样式以及效果图一并展示
1.HTML
<div class="rz-picter">
<img :src="avatar" class="img-avatar">
<input type="file" name="avatar" id="uppic" accept="image/gif,image/jpeg,image/jpg,image/png" @change="changeImage($event)" ref="avatarInput" class="uppic">
</div>
2.js
data() {
return {
avatar: require('../assets/jia.jpg'),
}
},
图片一定要以require 的方式引入 这里的图片仅用来美化 并不是上传的图片
3.js 写方法
changeImage(e) {
var file = e.target.files[0]
var reader = new FileReader()
var that = this
reader.readAsDataURL(file)
reader.onload = function(e) {
that.avatar = this.result
}
},
就这么几段代码一个上传功能就写好了
4.切记我这里用了css来将input type = file
的样式重新优化了,并且将图片做了定位 所以点击中间图片就可以触发上传
你需要你的需求去定义你的样式
5.运用原生javascript我做了一个判断图片是否上传的的判断
if(document.getElementById('uppic').value.length == '') {
Toast('请上传图片');
return
}
6.附上css代码
.uppic {
height: 3rem;
width: 6rem;
margin: 0 auto;
opacity: 0;
z-index: 99999;
}
.img-avatar {
position: absolute;
}
附上写此功能所有代码
<template>
<div class="renzheng">
<div class="rz-notice" v-bind:style="{ display: isno}">
<p>名片用来鉴别是相关人员,温馨提示:<img src="../assets/static/img-icon/lan_cha.png" @click="hiddenwords"></p>
</div>
<van-tabs v-model="active" swipeable>
<van-tab v-for="(item,index) in navArr" :title="item.name" class="v-tab">
<div v-if="index==0">
<div class="color-black" style="text-align: center;margin-top: 0.4rem;">请上传本人名片照片</div>
<div class="rz-picter">
<img :src="avatar" class="img-avatar">
<input type="file" name="avatar" id="uppic" accept="image/gif,image/jpeg,image/jpg,image/png" @change="changeImage($event)" ref="avatarInput" class="uppic">
</div>
<div class="cuxian"></div>
<div class="my-content-list">
<div class="color-black"><span style="margin-right: 0.6rem;">真实姓名:</span><input v-model="yoursname" placeholder="请输入您的真实姓名" /></div>
</div>
<div class="my-content-list">
<div class="color-black"><span style="margin-right: 0.6rem;">手机号码:</span><input type="number" max="11" v-model="yoursphone" placeholder="请输入您的手机号码" /></div>
</div>
<div class="yzbtn" @click="submitBtn">
立即认证
</div>
</div>
<div v-if="index==1">
<div class="color-black" style="text-align: center;margin-top: 0.4rem;">请上传本人身份证照片</div>
<div class="rz-picter">
<img src="../assets/jia.jpg" />
<p>上传人像页</p>
</div>
<div class="rz-picter">
<img src="../assets/jia.jpg" />
<p>上传国辉页</p>
</div>
<div class="cuxian"></div>
<div class="my-content-list">
<div class="color-black"><span style="margin-right: 0.6rem;">真实姓名:</span><input placeholder="请输入您的真实姓名" /></div>
</div>
<div class="my-content-list">
<div class="color-black"><span style="margin-right: 0.6rem;">手机号码:</span><input type="number" placeholder="请输入您的手机号码" /></div>
</div>
<div class="yzbtn">
立即认证
</div>
</div>
</van-tab>
</van-tabs>
</div>
</template>
<script>
import { Tab, Tabs } from 'vant';
import { Toast } from 'vant'
export default {
name: 'renzheng',
data() {
return {
yoursname: '',
yoursphone: '',
avatar: require('../assets/jia.jpg'),
isno: 'block',
active: 0,
navArr: [{
name: "身份认证"
},
{
name: "实名认证"
}
],
}
},
methods: {
hiddenwords() {
this.isno = 'none'
},
submitBtn() {
if(this.yoursname == '') {
Toast("请填写你的真实姓名");
return;
}
if(this.yoursphone == '' || this.yoursphone == null) {
Toast("请填写你的手机号码");
return;
}
if(document.getElementById('uppic').value.length == '') {
Toast('请上传图片');
return;
}
},
changeImage(e) {
var file = e.target.files[0]
var reader = new FileReader()
var that = this
reader.readAsDataURL(file)
reader.onload = function(e) {
that.avatar = this.result
}
},
},
mounted: function() {
}
}
</script>
<style>
.rz-notice {
padding: 0.2rem 0.3rem;
display: flex;
flex-direction: row;
justify-content: space-between;
align-items: center;
background: #F0F5FB;
color: #28D9EF;
}
.rz-notice img {
height: 0.22rem;
width: 0.22rem;
}
.rz-picter {
height: 3rem;
width: 6rem;
margin: 0.3rem auto;
border: 0.01rem solid #ededed;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
.uppic {
height: 3rem;
width: 6rem;
margin: 0 auto;
opacity: 0;
z-index: 99999;
}
.img-avatar {
position: absolute;
}
/*立即验证*/
.yzbtn {
width: 90%;
height: 0.8rem;
background: #FF6600;
border-radius: 0.06rem;
margin: 30px auto;
text-align: center;
line-height: 0.8rem;
color: #FFFFFF
}
/*修改原有tab样式*/
.van-tab {
color: #A3A3A3!important;
}
.van-tab--active {
color: #000!important;
}
.van-tabs__line {
background-color: #FF6600!important;
width: 0.7rem!important;
text-align: center!important;
align-items: center;
margin-left: 1.5rem;
}
.van-toast {
background-color: #FF6600;
color: #FFFFFF
}
.my-content-list {
padding: 0.3rem;
display: flex;
flex-direction: row;
justify-content: space-between;
border-bottom: 0.01rem solid #EDEDED;
}
</style>
总结
以上所述是小编给大家介绍的vue.js 图片上传并预览及图片更换功能的实现代码网站的支持!
来源:https://blog.csdn.net/ZXD1314520/article/details/82049801
标签:vue.js,上传,预览
0
投稿
猜你喜欢
GO语言延迟函数defer用法详解
2024-02-18 16:56:27
MySQL修改默认引擎和字符集详情
2024-01-14 21:37:27
python科学计算之scipy——optimize用法
2022-03-14 03:59:44
python中使用while循环的实例
2022-12-25 00:23:57
PHP 面向对象程序设计(oop)学习笔记(一) - 抽象类、对象接口、instanceof 和契约式编程
2023-11-19 20:31:59
Django利用cookie保存用户登录信息的简单实现方法
2021-03-22 16:47:26
Python自动创建Excel并获取内容
2023-12-31 01:42:07
Win10安装MySQL5.7.18winX64 启动服务器失败并且没有错误提示
2024-01-27 04:59:14
Vue.js 实现tab切换并变色操作讲解
2023-07-02 16:51:40
python pygame实现2048游戏
2021-02-25 15:15:45
Python爬虫之教你利用Scrapy爬取图片
2022-11-02 10:35:02
关于MySQL自增ID的一些小问题总结
2024-01-22 18:52:56
TensorFlow数据输入的方法示例
2022-04-27 03:32:03
Pytorch转keras的有效方法,以FlowNet为例讲解
2023-07-27 02:04:54
javascript中的关于类型转换的性能优化
2023-06-26 16:25:48
Pycharm简单使用教程(入门小结)
2021-09-03 04:13:04
利用Python自带PIL库扩展图片大小给图片加文字描述的方法示例
2022-11-30 20:40:01
Python实现自动化整理文件的示例代码
2021-11-04 02:39:36
Python 基于jwt实现认证机制流程解析
2022-07-15 00:25:30
Python 'takes exactly 1 argument (2 given)' Python error
2022-04-19 00:26:05