Rumah > hujung hadapan web > tutorial js > Bagaimana Mendapatkan Saiz Fail dan Dimensi Imej Sebelum Muat Naik dengan JavaScript?

Bagaimana Mendapatkan Saiz Fail dan Dimensi Imej Sebelum Muat Naik dengan JavaScript?

Mary-Kate Olsen
Lepaskan: 2024-11-25 12:39:10
asal
880 orang telah melayarinya

How to Get File Size and Image Dimensions Before Upload with JavaScript?

Saiz Fail dan Dimensi Imej Sebelum Muat Naik Menggunakan jQuery atau JavaScript

Untuk mendapatkan saiz fail, lebar imej dan ketinggian sebelum memuat naik ke tapak web, gunakan API Fail disediakan oleh HTML5 dan JavaScript.

Menggunakan API URL

Objek Blob akan diwakili sebagai URL untuk sumber imej.

<img src="blob:null/026cceb9-edr4-4281-babb-b56cbf759a3d">
Salin selepas log masuk
const EL_browse = document.getElementById('browse');
const EL_preview = document.getElementById('preview');

const readImage = file => {
  if (!(/^image\/(png|jpe?g|gif)$/).test(file.type))
    return EL_preview.insertAdjacentHTML('beforeend', `Unsupported format ${file.type}: ${file.name}<br>`);

  const img = new Image();
  img.addEventListener('load', () => {
    EL_preview.appendChild(img);
    EL_preview.insertAdjacentHTML('beforeend', `<div>${file.name} ${img.width}×${img.height} ${file.type} ${Math.round(file.size/1024)}KB<div>`);
    window.URL.revokeObjectURL(img.src); // Free some memory
  });
  img.src = window.URL.createObjectURL(file);
};

EL_browse.addEventListener('change', ev => {
  EL_preview.innerHTML = ''; // Remove old images and data
  const files = ev.target.files;
  if (!files || !files[0]) return alert('File upload not supported');
  [...files].forEach(readImage);
});
Salin selepas log masuk
#preview img { max-height: 100px; }
Salin selepas log masuk
<input>
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana Mendapatkan Saiz Fail dan Dimensi Imej Sebelum Muat Naik dengan JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan