• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

341
Views
Reaccionar: el tipo de entrada "archivo" ignora la propiedad `aceptar` cuando carga archivos usando arrastrar y soltar

Uso <input type="file" accept=".txt" /> con la propiedad accept. Lo configuré para aceptar, por ejemplo, solo archivos .txt . Y funciona bien si hace clic en input y abre el selector y no puede cargar archivos que no están permitidos por accept .

Pero, cuando carga archivos drag & drop , carga cualquier archivo ignorando accept .

Aquí hay un ejemplo: https://codesandbox.io/s/floral-tdd-11wt9?file=/src/App.js

Para reproducir el problema:

  • arrastre cualquier archivo desde su escritorio, espere .txt
  • mover y soltar en la entrada
  • verá un nombre de archivo (pero no debe cargarse)

P: ¿Cuál es la mejor manera de solucionar esto? Teniendo en cuenta que podría haber cualquier tipo de archivo y el tipo de archivo estándar file.type información excesiva sobre el tipo de archivo.

about 3 years ago · Juan Pablo Isaza
2 answers
Answer question

0

Cuando agrega la aceptación, el navegador le dice al sistema operativo que muestre solo los archivos que se mencionan pero el soporte, pero cuando arrastra y suelta esta característica se elimina. La mejor manera es escribir una función de validación que verifique si el dado archivo es compatible o no como

 const handleChange = (e) => { const newFiles = e.target.files; const fileName = newFiles[0].name; const extension = fileName.split(".").pop(); const isSupported = ["txt"].includes(extension); if (!isSupported) { alert("not supported"); setFiles(null); e.target.value = null; } else { setFiles(newFiles); }

};

aquí la ventaja de usar ["txt"].includes(extension) es que, puede agregar validación para múltiples tipos de archivos, simplemente restablezco la entrada con e.target.value = null; (cuando el archivo no es válido), pero puede usar su propia lógica allí

aquí hay un ejemplo de trabajo

about 3 years ago · Juan Pablo Isaza Report

0

Para evitar eliminar archivos no aceptados, debe agregar el controlador onDrop para la entrada:

 <input type="file" onDrop={handleDrop} accept="text/plain" {...otherProps} />

En onDrop , compruebe si se acepta el tipo de archivo soltado:

 const handleDrop = (e) => { const allowedTypes = new Set([e.target.accept]); if (!allowedTypes.has(e.dataTransfer.files[0].type)) { // stop event prepagation e.preventDefault(); } };

Aquí hay un ejemplo en vivo:

Editar kind-jennings-t8947

about 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error