vue.js3:用exif-js读取图片的exif信息(vue@3.2.36)

一,exif-js相关信息:

官网:

http://code.ciaoca.com/javascript/exif-js/
代码地址:
https://github.com/exif-js/exif-js

说明:刘宏缔的架构森林是一个专注架构的博客,

网站:https://blog.imgtouch.com
本文: https://blog.imgtouch.com/index.php/2023/06/01/vue-js3-yong-exifjs-du-qu-tu-pian-de-exif-xin-xi-vue-3-2-36/

         对应的源码可以访问这里获取: https://github.com/liuhongdi/
         或: https://gitee.com/liuhongdi

说明:作者:刘宏缔 邮箱: 371125307@qq.com

二,添加exif-js到项目中

1,从github下载代码,把exif.js文件复制到public/static/js目录下一份:如图:
2,在index.html中引入js代码:
<!DOCTYPE html>
<html lang="">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width,initial-scale=1.0">
    <link rel="icon" href="<%= BASE_URL %>favicon.ico">
    <script type="text/javascript" language="JavaScript" src="static/js/exif.js"></script>
    <title><%= htmlWebpackPlugin.options.title %></title>
  </head>
  <body>
    <noscript>
      <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without 
JavaScript enabled. Please enable it to continue.</strong> </noscript> <div id="app"></div> <!-- built files will be auto injected --> </body> </html>

注意我们所添加的是这一行:

<script type="text/javascript" language="JavaScript" src="static/js/exif.js"></script>

三,使用exif-js读取图片exif信息的js代码:

Exif.vue
<template>
  <div>
    <img v-if="imgSrc.length > 0" id="fg" :src="imgSrc" style="width:300px;" />
    <br/>

    选择图片读取exif信息:
    <input type="file" ref="hiddenfile" accept="image/*" @change="readExif" class="hiddenInput" />

    <div v-if="isExif == 1">
    <div v-for="(item, index) in tags " :key="index" style="display: flex;text-align: left;">
      <div style="width:200px; ">{{ index }}:</div>
      <div style="width:600px; ">
        {{ item }}
      </div>
    </div>
    </div>

     <div v-if="isExif == 0">
       图片无exif信息可读取
     </div>

  </div>
</template>

<script>
import {ref} from "vue"
export default {
  name: "ExifImg",
  setup() {
      //exif tags
      const tags = ref({});
      //当前图片是否存在exif
      const isExif = ref(-1);
      //图片的src
      const imgSrc = ref("");
      //读取exif
      const readExif = (e) => {
        let file = e.target.files[0];
        let reader = new FileReader();
        reader.readAsDataURL(file);
        reader.onload = () =>{
          imgSrc.value = reader.result;
          var img = new Image();
          img.src = imgSrc.value;
          img.onload = () => {
             // console.log("图片加载成功:");
            window.EXIF.getData(img, function(){
              let tags1 = window.EXIF.getAllTags(this);
              tags.value = tags1;
              if (Object.getOwnPropertyNames(tags.value).length >0) {
                isExif.value = 1;
              } else {
                isExif.value = 0;
              }
              var pretty = window.EXIF.pretty(this);
              console.log(pretty);
            });
          }
        }
      }

      return {
        readExif,
        tags,
        isExif,
        imgSrc,
      }
  }
}
</script>

<style scoped>
</style>

四,查看效果

五,查看vue框架的版本:

liuhongdi@lhdpc:/data/vue/imgtouch$ npm list vue
imgtouch@0.1.0 /data/vue/imgtouch
├─┬ @vue/cli-plugin-babel@5.0.4
│ └─┬ @vue/babel-preset-app@5.0.4
│ └── vue@3.2.36 deduped
├─┬ element-plus@2.2.2
│ ├─┬ @element-plus/icons-vue@1.1.4
│ │ └── vue@3.2.36 deduped
│ ├─┬ @vueuse/core@8.6.0
│ │ ├─┬ @vueuse/shared@8.6.0
│ │ │ └── vue@3.2.36 deduped
│ │ ├─┬ vue-demi@0.13.1
│ │ │ └── vue@3.2.36 deduped
│ │ └── vue@3.2.36 deduped
│ └── vue@3.2.36 deduped
└─┬ vue@3.2.36
└─┬ @vue/server-renderer@3.2.36
└── vue@3.2.36 deduped

 

posted @ 2022-06-08 18:54  刘宏缔的架构森林  阅读(2827)  评论(0编辑  收藏  举报