Проверка наличия образа с помощью javascript
Возможный дубликат:
Проверьте, существует ли изображение с заданным URL-адресом, используя jquery
Измените источник изображения, если файл существует
Я выбрал значение пути изображения из текстового поля в поле boxvalue и хочу проверить, существует ли изображение с помощью javascript.
var boxvalue = $('#UrlQueueBox').val();
Я просмотрел stackoverflow и нашел ниже, чтобы получить ширину/высоту изображения, но не хочу использовать это.
var img = document.getElementById('imageid');
Как я могу проверить, действительно ли это изображение из пути изображения?
Ответы
Ответ 1
// The "callback" argument is called with either true or false
// depending on whether the image at "url" exists or not.
function imageExists(url, callback) {
var img = new Image();
img.onload = function() { callback(true); };
img.onerror = function() { callback(false); };
img.src = url;
}
// Sample usage
var imageUrl = 'http://www.google.com/images/srpr/nav_logo14.png';
imageExists(imageUrl, function(exists) {
console.log('RESULT: url=' + imageUrl + ', exists=' + exists);
});
Ответ 2
Вы можете создать функцию и проверить свойство complete
.
function ImageExists(selector) {
var imageFound = $(selector);
if (!imageFound.get(0).complete) {
return false;
}
else if (imageFound.height() === 0) {
return false;
}
return true;
}
и назовите это funciton
var exists = ImageExists('#UrlQueueBox');
Такая же функция с url вместо селектора в качестве параметра (ваш случай):
function imageExists(url){
var image = new Image();
image.src = url;
if (!image.complete) {
return false;
}
else if (image.height === 0) {
return false;
}
return true;
}