Rumah > hujung hadapan web > View.js > Bagaimana untuk melaksanakan pemangkasan dan pemampatan imej dalam Vue?

Bagaimana untuk melaksanakan pemangkasan dan pemampatan imej dalam Vue?

WBOY
Lepaskan: 2023-06-25 10:27:33
asal
4715 orang telah melayarinya

Dengan pempopularan peranti mudah alih, permintaan untuk pemprosesan imej semakin tinggi, antaranya pemangkasan dan pemampatan imej merupakan keperluan yang agak biasa Artikel ini akan memperkenalkan cara melaksanakan pemangkasan dan pemampatan imej dalam Vue.

1. Pangkas gambar

  1. Pasang pemalam

Mula-mula anda perlu memasang pemalam vue-cropper, yang berasaskan cropperjs dan boleh melaksanakan fungsi pemangkasan imej dengan cepat.

npm install vue-cropper --save
Salin selepas log masuk
e
  1. introduce plug-in

introduce plug-in in main.js dan daftar:

import VueCropper from 'vue-cropper'
Vue.component('VueCropper', VueCropper)
Salin selepas log masuk
  1. add component

add component component dalam komponen:

<template>
  <div>
    <input type="file" ref="file" @change="getFile($event)" />
    <vue-cropper v-model="image" :guides="true"></vue-cropper>
    <button @click="getCroppedImage">裁剪图片</button>
    <div class="result">
      <img :src="croppedImage" alt="裁剪后的图片" v-if="croppedImage" />
    </div>
  </div>
</template>
Salin selepas log masuk
eget image
  1. define Image Object In In in data Dan objek imej yang dipangkas:
data () {
  return {
    image: null,
    croppedImage: null
  }
}
Salin selepas log masuk

Tambah kaedah getFile untuk mendapatkan imej yang dimuat naik:

getFile (event) {
  let file = event.target.files[0]
  let reader = new FileReader()
  reader.readAsDataURL(file)
  reader.onload = e => {
    this.image = e.target.result
  }
}
Salin selepas log masuk
Salin selepas log masuk

Pangkas imej
  1. Tambah kaedah getCroppedImage untuk memangkas imej:
rreee

Mampatkan imej

2. Selain memotong imej, Dalam sesetengah kes, kita juga perlu memampatkan imej untuk meningkatkan kelajuan pemuatan halaman Berikut ialah cara untuk mencapai pemampatan imej.

Pasang pemalam

  1. Pasang pemalam vue-image-compressor, yang berasaskan image-compressor.js dan boleh melaksanakan fungsi pemampatan imej dengan cepat.
  2. getCroppedImage () {
      this.$refs.cropper.getCroppedCanvas().toBlob(blob => {
        this.croppedImage = window.URL.createObjectURL(blob)
      })
    }
    Salin selepas log masuk
    e

introduce plug-in

  1. introduce plug-in in main.js dan daftar:
  2. npm install vue-image-compressor --save
    Salin selepas log masuk

add component

  1. add muat naik komponen dalam komponen:
  2. import ImageCompressor from 'vue-image-compressor'
    Vue.use(ImageCompressor)
    Salin selepas log masuk
    eget image

define objek imej di dalam data Dan objek imej termampat:
    <template>
      <div>
        <input type="file" ref="file" @change="getFile($event)" />
        <button @click="compressImage">压缩图片</button>
        <div class="result">
          <img :src="compressedImage" alt="压缩后的图片" v-if="compressedImage" />
        </div>
      </div>
    </template>
    Salin selepas log masuk
  1. Tambah kaedah getFile untuk mendapatkan imej yang dimuat naik:
  2. data () {
      return {
        image: null,
        compressedImage: null
      }
    }
    Salin selepas log masuk

Imej termampat

Tambah kaedah compressImage untuk memampatkan imej:
    getFile (event) {
      let file = event.target.files[0]
      let reader = new FileReader()
      reader.readAsDataURL(file)
      reader.onload = e => {
        this.image = e.target.result
      }
    }
    Salin selepas log masuk
    Salin selepas log masuk
  1. Antaranya adalah mampatan, parameter kualiti bermaksud Kualiti mampatan, maxWidth dan maxHeight mewakili lebar dan ketinggian maksimum, dan mimeType mewakili format imej termampat.
3. Contoh kod

Kod lengkap adalah seperti berikut:

compressImage () {
  let options = {
    quality: 0.7,
    maxWidth: 500,
    maxHeight: 500,
    mimeType: 'image/jpeg'
  }
  this.$compress(this.image, options).then(data => {
    this.compressedImage = data
  })
}
Salin selepas log masuk
4Ringkasan

Artikel ini memperkenalkan cara melaksanakan fungsi pemampatan dan pemampatan dalam Vue pemangkasan dan pemalam pihak ketiga digunakan untuk pemampatan vue-image-compressor, gunakan pemalam ini untuk melaksanakan fungsi pemprosesan imej dengan cepat dan meningkatkan kecekapan pembangunan.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan pemangkasan dan pemampatan imej dalam Vue?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan