欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue.js 圖片上傳并預(yù)覽及圖片更換功能的實(shí)現(xiàn)代碼

 更新時(shí)間:2018年08月27日 08:42:04   作者:新葉之扉之丹兒  
這篇文章主要介紹了vue.js 圖片上傳并預(yù)覽及圖片更換功能,小編主要圍繞我們?nèi)粘J褂霉δ艿睦幼鲋v解,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

這里講解是圖片上傳和圖片預(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中provide、inject的使用方法案例詳解

    vue中provide、inject的使用方法案例詳解

    本教程是介紹如何在vue中使用provide和inject,在 Vue 中,provide 和 inject 是用于實(shí)現(xiàn)祖先組件向后代組件傳遞數(shù)據(jù)的一種方式,對(duì)vue中provide、inject的使用方法感興趣的朋友一起看看吧
    2024-02-02
  • vue實(shí)現(xiàn)簡單的MVVM框架

    vue實(shí)現(xiàn)簡單的MVVM框架

    這篇文章給大家分享了基于vue實(shí)現(xiàn)一個(gè)簡單的MVVM框架的相關(guān)內(nèi)容,有需要的朋友們可以參考學(xué)習(xí)下。
    2018-08-08
  • vue獲取v-for異步數(shù)據(jù)dom的解決問題

    vue獲取v-for異步數(shù)據(jù)dom的解決問題

    這篇文章主要介紹了vue獲取v-for異步數(shù)據(jù)dom的解決問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vue+echarts實(shí)現(xiàn)堆疊柱狀圖

    vue+echarts實(shí)現(xiàn)堆疊柱狀圖

    這篇文章主要為大家詳細(xì)介紹了vue+echarts實(shí)現(xiàn)堆疊柱狀圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • vue頁面使用阿里oss上傳功能的實(shí)例(二)

    vue頁面使用阿里oss上傳功能的實(shí)例(二)

    本篇文章主要介紹了vue頁面使用阿里oss上傳功能的實(shí)例(二),主要介紹OSS管理控制臺(tái)設(shè)置訪問權(quán)限、角色等,有興趣的可以了解一下
    2017-08-08
  • 使用Vue3+PDF.js實(shí)現(xiàn)PDF預(yù)覽功能

    使用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-12
  • 解決使用vue.js路由后失效的問題

    解決使用vue.js路由后失效的問題

    下面小編就為大家分享一篇解決使用vue.js路由后失效的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue實(shí)現(xiàn)點(diǎn)擊后文字變色切換方法

    Vue實(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)按需加載

    這篇文章主要介紹了從0搭建Vue3組件庫如何使用?glup?打包組件庫并實(shí)現(xiàn)按需加載,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • vue時(shí)間轉(zhuǎn)換的幾種方式

    vue時(shí)間轉(zhuǎn)換的幾種方式

    這篇文章主要介紹了vue時(shí)間轉(zhuǎn)換的幾種方式,需要的朋友可以參考下
    2022-05-05

最新評(píng)論