vue.js 圖片上傳并預(yù)覽及圖片更換功能的實(shí)現(xiàn)代碼
這里講解是圖片上傳和圖片預(yù)覽。主要是圍繞我們常用功能的列子做講解 ,并且沒(méi)有格外引入其他js 所以你復(fù)制過(guò)去做簡(jiǎn)單修改便可以看到效果
效果圖:


樣式以及效果圖一并展示
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 的方式引入 這里的圖片僅用來(lái)美化 并不是上傳的圖片
3.js 寫(xiě)方法
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
}
},
就這么幾段代碼一個(gè)上傳功能就寫(xiě)好了
4.切記我這里用了css來(lái)將input type = file 的樣式重新優(yōu)化了,并且將圖片做了定位 所以點(diǎn)擊中間圖片就可以觸發(fā)上傳

你需要你的需求去定義你的樣式
5.運(yùn)用原生javascript我做了一個(gè)判斷圖片是否上傳的的判斷
if(document.getElementById('uppic').value.length == '') {
Toast('請(qǐng)上傳圖片');
return
}
6.附上css代碼
.uppic {
height: 3rem;
width: 6rem;
margin: 0 auto;
opacity: 0;
z-index: 99999;
}
.img-avatar {
position: absolute;
}
附上寫(xiě)此功能所有代碼
<template>
<div class="renzheng">
<div class="rz-notice" v-bind:style="{ display: isno}">
<p>名片用來(lái)鑒別是相關(guān)人員,溫馨提示:<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;">請(qǐng)上傳本人名片照片</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;">真實(shí)姓名:</span><input v-model="yoursname" placeholder="請(qǐng)輸入您的真實(shí)姓名" /></div>
</div>
<div class="my-content-list">
<div class="color-black"><span style="margin-right: 0.6rem;">手機(jī)號(hào)碼:</span><input type="number" max="11" v-model="yoursphone" placeholder="請(qǐng)輸入您的手機(jī)號(hào)碼" /></div>
</div>
<div class="yzbtn" @click="submitBtn">
立即認(rèn)證
</div>
</div>
<div v-if="index==1">
<div class="color-black" style="text-align: center;margin-top: 0.4rem;">請(qǐng)上傳本人身份證照片</div>
<div class="rz-picter">
<img src="../assets/jia.jpg" />
<p>上傳人像頁(yè)</p>
</div>
<div class="rz-picter">
<img src="../assets/jia.jpg" />
<p>上傳國(guó)輝頁(yè)</p>
</div>
<div class="cuxian"></div>
<div class="my-content-list">
<div class="color-black"><span style="margin-right: 0.6rem;">真實(shí)姓名:</span><input placeholder="請(qǐng)輸入您的真實(shí)姓名" /></div>
</div>
<div class="my-content-list">
<div class="color-black"><span style="margin-right: 0.6rem;">手機(jī)號(hào)碼:</span><input type="number" placeholder="請(qǐng)輸入您的手機(jī)號(hào)碼" /></div>
</div>
<div class="yzbtn">
立即認(rèn)證
</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: "身份認(rèn)證"
},
{
name: "實(shí)名認(rèn)證"
}
],
}
},
methods: {
hiddenwords() {
this.isno = 'none'
},
submitBtn() {
if(this.yoursname == '') {
Toast("請(qǐng)?zhí)顚?xiě)你的真實(shí)姓名");
return;
}
if(this.yoursphone == '' || this.yoursphone == null) {
Toast("請(qǐng)?zhí)顚?xiě)你的手機(jī)號(hào)碼");
return;
}
if(document.getElementById('uppic').value.length == '') {
Toast('請(qǐng)上傳圖片');
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;
}
/*立即驗(yàn)證*/
.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>
總結(jié)
以上所述是小編給大家介紹的vue.js 圖片上傳并預(yù)覽及圖片更換功能的實(shí)現(xiàn)代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue3項(xiàng)目中引用TS語(yǔ)法的實(shí)例講解
這篇文章主要介紹了Vue3項(xiàng)目中引用TS語(yǔ)法的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05
淺談webpack編譯vue項(xiàng)目生成的代碼探索
本篇文章主要介紹了淺談webpack編譯vue項(xiàng)目生成的代碼探索,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
Vue3.2?新增指令?v-memo?用法詳解(提高性能利器)
v-memo 接受一個(gè)依賴(lài)的數(shù)組,依賴(lài)的數(shù)組變化,v-memo 所對(duì)應(yīng)的 DOM 包括子集將會(huì)重新渲染,這篇文章主要介紹了Vue3.2?新增指令?v-memo?用法,提高性能的又一利器,需要的朋友可以參考下2022-09-09
Vue使用Intersection?Observer檢測(cè)元素是否展示
Intersection?Observer?是一個(gè)瀏覽器原生的?API,用于異步觀(guān)察目標(biāo)元素與其祖先元素或頂部視口之間的交叉狀態(tài)變化,本文就來(lái)聊聊如何使用Intersection?Observer檢測(cè)元素是否展示吧2024-11-11
Vue3計(jì)算屬性computed和監(jiān)聽(tīng)屬性watch區(qū)別解析
計(jì)算屬性適用于對(duì)已有的數(shù)據(jù)進(jìn)行計(jì)算,派生新的數(shù)據(jù),并在模板中使用;而監(jiān)聽(tīng)屬性適用于監(jiān)聽(tīng)數(shù)據(jù)的變化,并執(zhí)行一些特定的操作,根據(jù)具體的需求和場(chǎng)景,選擇適合的機(jī)制這篇文章主要介紹了Vue3計(jì)算屬性computed和監(jiān)聽(tīng)屬性watch,需要的朋友可以參考下2024-02-02
vue.config.js中配置configureWebpack和chainWebpack以及一些常用的配置
configureWebpack和chainWebpack都是Vue CLI中用于修改Webpack配置的工具,configureWebpack可以通過(guò)對(duì)象或函數(shù)修改配置,簡(jiǎn)單直接;chainWebpack則使用WebpackChainAPI,適合復(fù)雜配置,兩者可以結(jié)合使用,以達(dá)到更精細(xì)的配置需求,幫助開(kāi)發(fā)者優(yōu)化項(xiàng)目構(gòu)建2024-10-10

