Dalam soalan sebelumnya, anda cuba menyerahkan data imej dalam permintaan POST. Pendekatan semasa anda melibatkan penggunaan jQuery.ajax untuk mendapatkan semula imej, tetapi anda menghadapi imej rosak disebabkan ketidakpadanan jenis data.
Jenis Data jQuery Terhad
jQuery.ajax menyokong beberapa jenis data tetapi tidak menyertakan imej secara eksplisit. Oleh itu, mengakses imej sebagai gumpalan menggunakan jQuery sahaja tidak boleh dilaksanakan.
Penyelesaian XMLHttpRequest Asli
Untuk menyelesaikan isu ini, anda boleh menggunakan XMLHttpRequest asli. Berikut ialah contoh:
var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { var img = document.getElementById('img'); var url = window.URL || window.webkitURL; img.src = url.createObjectURL(this.response); } } xhr.open('GET', 'http://jsfiddle.net/img/logo.png'); xhr.responseType = 'blob'; xhr.send();
Skrip ini akan mencipta objek XMLHttpRequest, mengkonfigurasinya untuk menerima respons gumpalan dan menggunakan sifat URL Blob untuk memaparkan imej dalam elemen HTML.
Penyelesaian jQuery 3
Dalam jQuery 3, pendekatan baharu ialah tersedia:
jQuery.ajax({ url:'https://images.unsplash.com/photo-1465101108990-e5eac17cf76d?ixlib=rb-0.3.5&q=85&fm=jpg&crop=entropy&cs=srgb&ixid=eyJhcHBfaWQiOjE0NTg5fQ%3D%3D&s=471ae675a6140db97fea32b55781479e', cache:false, xhr:function(){// Seems like the only way to get access to the xhr object var xhr = new XMLHttpRequest(); xhr.responseType= 'blob' return xhr; }, success: function(data){ var img = document.getElementById('img'); var url = window.URL || window.webkitURL; img.src = url.createObjectURL(data); }, error:function(){ } });
Dalam contoh ini, fungsi xhr digunakan untuk mengkonfigurasi objek XMLHttpRequest dan responseType secara eksplisit ditetapkan kepada 'gumpalan'. Ini membolehkan jQuery mendapatkan semula imej sebagai gumpalan dan memaparkannya dalam elemen imej.
Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Imej sebagai Gumpalan Menggunakan jQuery dan JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!