This question has been posted on Stack before, but none so specific as to what I'm trying to understand.
The simplest way to check if a URL is corrrect to send a http Head request. But how do you use that to specify the URL ?
I found this in a previous post :
function UrlExists(url) { var http = new XMLHttpRequest(); http.open('HEAD', url, false); http.send(); return http.status!=404; }
But it doesn't seem to run in firebug for a few reasons.
My apologies ahead of time for being daft.
var urlExists = function(url){ //When I call the function, code is still executing here. $. ajax({ type: 'HEAD', url: url, success: function() { return true; }, error: function() { return false; } }); //But not here... }
I'd recommend to use jQuery for correct cross-browser ajax requests:
function UrlExists(url, cb){ jQuery.ajax({ url: url, dataType: 'text', type: 'GET', complete: function(xhr){ if(typeof cb === 'function') cb.apply(this, [xhr.status]); } }); }
Usage:
UrlExists('/path/script.pl', function(status){ if(status === 200){ // file was found } else if(status === 404){ // 404 not found } });
Modern, cross and short way
checkLink = async url => (await fetch(url)).ok
which is same of:
async checkLink(url) { return (await fetch(url)).ok }
which is same of:
async function checkLink(url) { return (await fetch(url)).ok }
which is same of:
Note: Starting with Gecko 30.0 (Firefox 30.0 / Thunderbird 30.0 / SeaMonkey 2.27), Blink 39.0, and Edge 13, synchronous requests on the main thread have been deprecated due to their negative impact on the user experience.
Cross solution (old, deprecated)
function UrlExists(url) { var http = new XMLHttpRequest(); http.open('HEAD', url, false); http.send(); return http.status==200; }
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With