vue.js 圖片上傳并預(yù)覽及圖片更換功能的實(shí)現(xiàn)代碼
這里講解是圖片上傳和圖片預(yù)覽。主要是圍繞我們常用功能的列子做講解 ,并且沒有格外引入其他js 所以你復(fù)制過去做簡單修改便可以看到效果
效果圖:
樣式以及效果圖一并展示
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 } },
就這么幾段代碼一個(gè)上傳功能就寫好了
4.切記我這里用了css來將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; }
附上寫此功能所有代碼
<template> <div class="renzheng"> <div class="rz-notice" v-bind:style="{ display: isno}"> <p>名片用來鑒別是相關(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>上傳人像頁</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;">真實(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í)顚懩愕恼鎸?shí)姓名"); return; } if(this.yoursphone == '' || this.yoursphone == null) { Toast("請(qǐng)?zhí)顚懩愕氖謾C(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ì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
vue獲取v-for異步數(shù)據(jù)dom的解決問題
這篇文章主要介紹了vue獲取v-for異步數(shù)據(jù)dom的解決問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03使用Vue3+PDF.js實(shí)現(xiàn)PDF預(yù)覽功能
項(xiàng)目中有一個(gè)需要預(yù)覽下載pdf的需求,網(wǎng)上找了很久,決定使用 pdf.js 完成,下面這篇文章主要給大家介紹了關(guān)于使用Vue3+PDF.js實(shí)現(xiàn)PDF預(yù)覽功能的相關(guān)資料,需要的朋友可以參考下2022-12-12Vue實(shí)現(xiàn)點(diǎn)擊后文字變色切換方法
下面小編就為大家分享一篇Vue實(shí)現(xiàn)點(diǎn)擊后文字變色切換方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-02-02從0搭建Vue3組件庫如何使用?glup?打包組件庫并實(shí)現(xiàn)按需加載
這篇文章主要介紹了從0搭建Vue3組件庫如何使用?glup?打包組件庫并實(shí)現(xiàn)按需加載,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03