vue.js 이미지 업로드 및 미리 보기 및 이미지 교체 기능 의 실현 코드

여기 설명 은 사진 업로드 와 사진 미리 보기 입 니 다.주로 우리 가 자주 사용 하 는 기능 의 열 을 중심 으로 설명 을 하고 다른 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 사진 업로드 및 미리 보기 및 이미지 교체 기능 의 실현 코드 입 니 다.여러분 에 게 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 메 시 지 를 남 겨 주세요.소 편 은 제때에 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!

좋은 웹페이지 즐겨찾기