I was wondering if there was a way to use jQuery to find out the file size for a PDF that i'm linking to a webpage.
I want to make it so that on hovering over the download link, a modal box pops up saying the file size of the PDF. I can do the second bit, the only thing i'd like to know is how to find out the file size. I dont know if jQuery is capable of this. If not then too bad i guess..
Cheers in advance.
In the answer above, Chrome 21 and Safari 6 did not have a fileSize member, but does have size. Use:
fileInput.files[0].size
Here is working snippet to find the file size in javascript without going to the server, if you are about to upload the file to the server.
This idea helps to restrict the file size before uploading big files to the server.
The only way that I can think of to do this would be to create a web service that would return you the filesize of the PDF.
I feel like this is too much to be doing client-side, but I don't know the details of your application, so presuming you have to do it with jQuery... you can do a HEAD request and look at the Content-Length header. Earlier I recommended the jqHead plugin, but after I tried to use it I found that it was broken.
Here's a working example that doesn't depend on any extra plugins: http://host.masto.com/~chris/so/jqhead.html
The meat of it is very simple:
If you know the file size beforehand, you can put that in the title attribute of the download link. You can also use jQuery to show a custom popup.
Otherwise, there is no way to get just the file size (content-length) of a URL without actually downloading the whole content AFAIK.