Subscribe

viernes, 29 de junio de 2012

File API de html5

Hasta la llegada de HTML5 era imposible realizar operaciones con los ficheros de un formulario, como por ejemplo:

  • Conocer el tamaño de un fichero y el tipo antes de ser enviado para poder realizar validaciones sin necesidad de enviarlo.
  • Poder seleccionar más de un fichero en un mismo input file.
  • Usar drag & drop para adjuntar un fichero a un formulario.
Miento, si había formas, pero todas ellas pasaban por usar otro tipo de elementos como por ejemplo, flash o applet de java

Con HTML5 disponemos de una nueva api con la que poder trabajar con los ficheros seleccionados en un formulario. En concreto disponemos de las siguientes funciones:

  • File: Nos permite acceder a información de un fichero individual como es el nombre, el tamaño, el mimetype o una referencia un manejador del fichero.
  • FileList: Nos permite las mismas acciones que File pero aplicadas a una lista de ficheros. Se utiliza cuando usamos un <input type="file" multiple>.
  • Blob: Nos permite cortar un fichero por rango de bytes. (Este todavía no lo he podido probar)
Como casi siempre en HTML5 no todos los navegadores soportan actualmente estas api, en principio las últimas versiones de Firefox, Chrome y Opera no tendremos problemas, pero si en Internet Explorer y Safari.

Para saber si el navegador del cliente soporta estas api podemos usar el código:

if (window.File && window.FileReader && window.FileList && window.Blob) {
  // Todas las APIs soportadas.
} else {
  alert('La API de FILE no es soportada en este navegador.');
}

A modo de ejemplo tenéis el siguiente código que muestra en un div la lista de todos los ficheros seleccionado y la información asociada a él.


<input type="file" id="files" name="files[]" multiple />
<output id="list"></output>

<script>
  function handleFileSelect(evt) {
    var files = evt.target.files; // FileList object

    // files is a FileList of File objects. List some properties.
    var output = [];
    for (var i = 0, f; f = files[i]; i++) {
      output.push('<li><strong>', escape(f.name), '</strong> (', f.type || 'n/a', ') - ',
                  f.size, ' bytes, last modified: ',
                  f.lastModifiedDate ? f.lastModifiedDate.toLocaleDateString() : 'n/a',
                  '</li>');
    }
    document.getElementById('list').innerHTML = '<ul>' + output.join('') + '</ul>';
  }

  document.getElementById('files').addEventListener('change', handleFileSelect, false);
</script>

Espero que os sea útil. Yo ya le he encontrado alguna funcionalidad como por ejemplo, validar un formulario antes de ser enviado y mostrar por pantalla el tamaño del formulario que se va a enviar para calcular el tiempo medio de espera.


56 comentarios:

Anónimo dijo...

amigo como es que se hace esto

Protox dijo...

Muy buen blog.... muy util para los que empiezan

Lalit jain dijo...

very nice post HTML5 Web Development

HTML5 is the next generation and fifth version of HTML technology for content-rich website development.HTML5 is the latest addition to the World

Wide Web.
Our experience in HTML5 development empowers us to take up challenging project and deliver promising results with utmost perfection.

Unknown dijo...
Este comentario ha sido eliminado por el autor.
Unknown dijo...
Este comentario ha sido eliminado por el autor.
Unknown dijo...

Si quieres aprender html5 y CSS3 os dejo un artículo muy completo para aprender a crear un formulario de contacto:
http://informaticayfinanzas.blogspot.com/2014/01/como-hacer-un-formulario-de-contacto.html

psd to html dijo...

Nicely written post.

SiliconITHub dijo...

Responsive HTML5 Web design has the solution. The conception behind the amalgam of JavaScript, CSS and CSS3 is to build the flowing website design which is capable to contract, expand, remove or rearrange with user's screen size accordingly and become accessible on all internet devices.

rah=jiv dijo...

thanks for your posting ...............

online trainings

itabhyas dijo...
Este comentario ha sido eliminado por el autor.
Unknown dijo...


We at Spark square measure committed to impact the productivity of our shoppers through our distinct coaching methodologies, tailored content and delivery systems. We interact with our shoppers to supply finish to finish Learning and Development solutions and thereby supply support to boost their sales productivity, distribution network, method and compliance, ways that of operating, client expertise and supply pre-hire solutions.Visit: HR Training in India

Unknown dijo...

Hai Author Good Information that i found here,do not stop sharing and Please keep updating us..... Thanks

Sandeep SEO dijo...

Thank you for sharing this useful story. I think you shared the information is helpful to me and useful to others also.........................View More Information for Oracle Fusion Financials Course Details.

Unknown dijo...

Nice Post! It is really interesting to read from the beginning & I would like to share your blog to my circles, keep sharing…
Full Stack Training in Hyderabad

Rajesh dijo...

Very nice post here and thanks for it .I always like and such a super contents of these post.Excellent and very cool idea and great content of different kinds of the valuable information's.
Oracle Fusion SCM Training in Hyderabad

Unknown dijo...

THANKS FOR GOOD INFORMATION
http://spunksoft.com/course/sap-s4-hana-simple-finance-training-in-hyderabad/

Sannihitha Technologies dijo...

Very informative and well written post! Quite interesting and nice topic chosen for the post.
thanks for sharing this nice post,
MS Office training institute in hyderabad

Jaweed Khan dijo...

THANKS fOR SHARING YOUR INFORMATION PLEASE KEEP UPDATING US Time Went On Reading Your Article https://nareshit.in/html-javascript-training/

anirudh dijo...

The information which you have provided is very good. It is very useful who is looking for HTML5 Learning

Admin dijo...

I just stumbled over this page and have to say - wow. The site is really good and kept up to date. Continue like
Umiversity Of Kota BCOM 1st, 2nd & Final Year TimeTable 2020
Rani Durgavati VishwaVidhyalaya BCOM 1st, 2nd & Final Year TimeTable 2020

sara jenifer dijo...

You’d outstanding guidelines there. I did a search about the field and identified that very likely the majority will agree with your web page.
Agra University BCom 1st, 2nd & Final Year Time Table 2020
Allahabad University BCom 1st, 2nd & Final Year Time Table 2020
Maharaja Surajmal Brij University BCOM 1st, 2nd & Final Year TimeTable 2020
Delhi University BCOM 1st, 2nd & Part 3rd TimeTable 2020



Jack sparrow dijo...


I am reading your post from the beginning, it was so interesting to read & I feel thanks to you for posting such a good blog, keep updates regularly.i want to share about java advanced tutorials and advanced java training videos .

Aruna dijo...

I learned a lots of informative Things about Java from your sites...Content flows are in Good Manner.Looking for Best Java Training with placements then Visit here for more... Java training in chennai | Java training in annanagar | Java training in omr | Java training in porur | Java training in tambaram | Java training in velachery

Sowmiya R dijo...

Awesome Post.Your information is really interesting. The content show cases your in-depth knowledge. Thanks for Sharing.
Oracle Training in Chennai | Certification | Online Course Training | Oracle Training in Bangalore | Certification | Online Course Training | Oracle Training in Hyderabad | Certification | Online Course Training | Oracle Training in Online | Certification | Online Course Training | Hadoop Training in Chennai | Certification | Online Course Training

shankarjaya dijo...

I would really like to read some personal experiences like the way, you've explained
through the above article. I'm glad for your achievements and would probably like to see much more in the near future. Thanks for share.
Salesforce Training in Chennai

Salesforce Online Training in Chennai

Salesforce Training in Bangalore

Salesforce Training in Hyderabad

Salesforce training in ameerpet

Salesforce Training in Pune

Salesforce Online Training

Salesforce Training





jenani dijo...

Excellent! I love to post a comment that "The content of your post is awesome" Great work.Thanks for Sharing This Article.It is very so much valuable content. I hope these Commenting lists will help to my website
Java Training in Chennai

Java Training in Velachery

Java Training in Tambaram

Java Training in Porur

Java Training in OMR

Java Training in Annanagar



Livewell Hospital dijo...

Thank you for sharing this useful article with use. This blog is a very helpful in future.

https://www.ahmedabadcomputereducation.com/course/php-training-course/

Amrita Bansal dijo...

Good Post! , it was so good to read and useful to improve my knowledge as an updated one, keep blogging. After seeing your article I want to say that also a well-written article with some very good information which is very useful for the readers....thanks for sharing it and do share more posts like this.

Devops Training in Gurgaon
Docker Kubernetes training in Gurgaon

Ekku2324@ dijo...

Thank you for sharing this useful article with us. This blog is a very helpful to me in future. Keep sharing informative articles with us.
https://www.paygonline.site/

Ekku2324@ dijo...

Thank you for sharing this useful article. This blog is a very helpful to me. Keep sharing informative articles with us.

https://www.france-collectivites.fr/

Ekku2324@ dijo...

Great sources for knowledge. Thank you for sharing this helpful article. It is very useful for me.

https://www.ahmedabadcomputereducation.com/course/laravel-training-course/

Livewell Hospital dijo...

Thank you for sharing this useful article with us. This blog is a very helpful to me. Keep sharing informative articles with us.

https://www.sdsfin.in/services/project-finance-consultants-in-ahmedabad/

Livewell Hospital dijo...

Thank you for sharing this useful article with us. This blog is a very helpful to me. Keep sharing informative articles with us.

https://www.sdsfin.in/services/project-finance-consultants-in-ahmedabad/

Livewell Hospital dijo...

Its very informative blog and I am exactly looking this type of blog. Thank you for sharing this beautiful blog.

https://superurecoat.com/titanium-iso-propoxide/

Livewell Hospital dijo...

This information is very useful for me and other too. Thank you for sharing this type blog with us.

best spine doctor in ahmedabad

spine specialist in ahmedabad

pain medicine specialist

best spine hospital in ahmedabad

Livewell Hospital dijo...

Thank you for the great information. Keep Sharing it!

https://saroitapes.com/

Unknown dijo...

Back Pain Treatment in Ahmedabad https://livewellhospital.com/back-pain-treatment-in-ahmedabad/

Ekku2324@ dijo...

Thanks for sharing informative article.

https://web30india.com/

Ekku2324@ dijo...

Excellent Article. Kepp Sharing with us!

PHP Web Development
Web Application Development
Cloud Web Application
Web Application Security Expertise
Front End Development & UX Design
Multi Platform Integration Services
Hire PHP Programmer

Parul Pathak dijo...

This site helps to clear your all query. davv ba 3rd year result
osmania university degree result This is really worth reading. nice informative article.

Mohit dijo...

usefull article.we like your blog.thanks for sharing informative article.
Best Home Loan Provider in Vadodara

srija dijo...

Really nice blog.I suggest you to Become QA Certified Professional with QA Online Training

bhaskar dijo...

Hello,
Your blog has a lot of valuable information . Thanks for your time on putting these all together.. Really helpful blog..I just wanted to share information about
devops online training

Unknown dijo...

aşk kitapları
youtube abone satın al
cami avizesi
cami avizeleri
avize cami
no deposit bonus forex 2021
takipçi satın al
takipçi satın al
takipçi satın al
takipcialdim.com/tiktok-takipci-satin-al/
instagram beğeni satın al
instagram beğeni satın al
btcturk
tiktok izlenme satın al
sms onay
youtube izlenme satın al
no deposit bonus forex 2021
tiktok jeton hilesi
tiktok beğeni satın al
binance
takipçi satın al
uc satın al
sms onay
sms onay
tiktok takipçi satın al
tiktok beğeni satın al
twitter takipçi satın al
trend topic satın al
youtube abone satın al
instagram beğeni satın al
tiktok beğeni satın al
twitter takipçi satın al
trend topic satın al
youtube abone satın al
takipcialdim.com/instagram-begeni-satin-al/
perde modelleri
instagram takipçi satın al
instagram takipçi satın al
takipçi satın al
instagram takipçi satın al
betboo
marsbahis
sultanbet

Unknown dijo...

instagram takipçi satın al
instagram takipçi satın al
instagram takipçi satın al
instagram takipçi satın al
instagram takipçi satın al
instagram takipçi satın al
instagram takipçi satın al

Jobi Johnson dijo...

Our the purpose is to share the reviews about the latest Jackets,Coats and Vests also share the related Movies,Gaming, Casual,Faux Leather and Leather materials available Fury Jacket

hirededicatedresources dijo...

Web 3.0 India is the most trusted Web3 Blockchain Development and NFT Development Company in USA. We also provides ICO, STO development for cryptocurrency
Android Mobile App Development in Ahmedabad
https://web30india.com/

Anónimo dijo...

Excellent Article!!! I like the helpful information you provide in your article.

Banasthali Vidhyapith time table

George Mark dijo...

Thank you very much for this great post. Fonzie Leather Jacket

apsu ba 1st year result dijo...

Nice Information, your blog is sharing unique information...
apsu ba 2nd year result | apsu ba 3rd year result.

Zey dijo...

betmatik
kralbet
betpark
mobil ödeme bahis
tipobet
slot siteleri
kibris bahis siteleri
poker siteleri
bonus veren siteler
QEDS

melis dijo...

canlı sex hattı
heets
salt likit
salt likit
puff bar
ZYG

ozan dijo...

malatya
elazığ
kadıköy
istanbul
şişli

CF44

engin dijo...

bayrampaşa
güngören
hakkari
izmit
kumluca
5XQGK

Papatya dijo...

salt likit
salt likit
MVDX

zeynep dijo...

https://saglamproxy.com
metin2 proxy
proxy satın al
knight online proxy
mobil proxy satın al
NCK

Publicar un comentario