vue.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.원생 자 바스 크 립 트 를 활용 하여 사진 업로드 여 부 를 판단 하 는 판단 을 했 습 니 다.
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 사진 업로드 및 미리 보기 및 이미지 교체 기능 의 실현 코드 입 니 다.여러분 에 게 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 메 시 지 를 남 겨 주세요.소 편 은 제때에 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
[백견불여일타/Vue.js] 4장 - 입력 폼 데이터 가져오기v-model 데이터 입력 select 지난 장에서는 v-bind를 이용해서 HTML 태그 속성 값을 Vue로 다루는 법을 배웠습니다. 이번에는 사용자가 입력한 데이터를 Vue로 가져오는 법에 대해 다룹니다. 웹 페...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.