Jak wyczyścić dane wejściowe pliku HTML za pomocą JavaScript?

154

Chcę wyczyścić dane wejściowe pliku w moim formularzu.

Wiem o ustawianiu źródeł na tę samą metodę ... Ale ta metoda nie usunie wybranej ścieżki pliku.

Uwaga : chciałbym uniknąć konieczności ponownego ładowania strony, resetowania formularza lub wykonywania połączenia AJAX.

czy to możliwe?

thomaux
źródło

Odpowiedzi:

-10

Co powiesz na usunięcie tego węzła i utworzenie nowego o tej samej nazwie?

DFectuoso
źródło
46
co masz na myśli, proszę podać przykład.
1
stracisz swoje programy obsługi, takie jak ten: var inputPhoto = document.getElementById ('photoInput'); inputPhoto.addEventListener ('change', handler_file, false);
Rui Martins
Zagłosowano za brakujące wyjaśnienie!
Jason
212

Istnieją 3 sposoby na wyczyszczenie danych wejściowych za pomocą javascript:

  1. ustaw właściwość value na pustą lub null.

    Działa dla IE11 + i innych nowoczesnych przeglądarek.

  2. Utwórz nowy element wejściowy pliku i zastąp stary.

    Wadą jest utrata detektorów zdarzeń i właściwości expando.

  3. Zresetuj formularz właściciela za pomocą metody form.reset ().

    Aby uniknąć wpływu na inne elementy wejściowe w tym samym formularzu właściciela, możemy utworzyć nowy pusty formularz i dołączyć element wejściowy pliku do tego nowego formularza i zresetować go. W ten sposób działa dla wszystkich przeglądarek.

Napisałem funkcję javascript. demo: http://jsbin.com/muhipoye/1/

function clearInputFile(f){
    if(f.value){
        try{
            f.value = ''; //for IE11, latest Chrome/Firefox/Opera...
        }catch(err){ }
        if(f.value){ //for IE5 ~ IE10
            var form = document.createElement('form'),
                parentNode = f.parentNode, ref = f.nextSibling;
            form.appendChild(f);
            form.reset();
            parentNode.insertBefore(f,ref);
        }
    }
}
cuixiping
źródło
1
Czy nie powinniśmy również później usunąć utworzonego formularza?
Andrey
1
Nie, nie musisz. element formularza nie został dołączony do drzewa dokumentu strony.
cuixiping
5
Wystarczy słowo ostrzeżenia, jeśli zastosujesz podejście 2. lub 3., jeśli chcesz zachować zdarzenia i inne atrybuty, które zostały programowo dodane do elementu. W moim przypadku dodałem zdarzenie onclick do elementu formularza, który zniknął po resecie formularza. W takim przypadku podejście 1. jest lepsze. (Zostało to odnotowane dla 2., ale może się również zdarzyć w 3.)
Wolfie Inu
85

tl; dr : W przypadku nowoczesnych przeglądarek po prostu użyj

input.value = '';

Stara odpowiedź:

Co powiesz na:

input.type = "text";
input.type = "file";

Nadal muszę zrozumieć, dlaczego to nie działa z zestawem webkit .

W każdym razie działa to z IE9>, Firefox i Operą.
Sytuacja z webkitem polega na tym, że wydaje mi się, że nie mogę zmienić go z powrotem do pliku.
W przypadku IE8 sytuacja jest taka, że ​​zgłasza wyjątek bezpieczeństwa.

Edycja: W przypadku Webkit, Opera i Firefox działa to jednak:

input.value = '';

(sprawdź powyższą odpowiedź z tą propozycją)

Zobaczę, czy uda mi się znaleźć przyjemniejszy, bardziej przejrzysty sposób na zrobienie tej między przeglądarkami bez potrzeby GC.

Edit2:

try{
    inputs[i].value = '';
    if(inputs[i].value){
        inputs[i].type = "text";
        inputs[i].type = "file";
    }
}catch(e){}

Działa z większością przeglądarek. Nie działa z IE <9, to wszystko.
Testowane na firefox 20, chrome 24, opera 12, IE7, IE8, IE9 i IE10.

brunoais
źródło
35

Ustawienie wartości na '' nie działa we wszystkich przeglądarkach.

Zamiast tego spróbuj ustawić wartość nulltak:

document.getElementById('your_input_id').value= null;

EDYCJA: Dostaję bardzo ważne powody bezpieczeństwa, aby nie pozwolić JS na ustawienie danych wejściowych pliku, jednak wydaje się rozsądne zapewnienie prostego mechanizmu czyszczenia już wybranych danych wyjściowych. Próbowałem użyć pustego ciągu, ale nie działało to we wszystkich przeglądarkach,NULL działał we wszystkich przeglądarkach, które próbowałem (Opera, Chrome, FF, IE11 + i Safari).

EDYCJA: Należy pamiętać, że ustawienie NULLdziała we wszystkich przeglądarkach, a ustawienie na pusty ciąg nie działa.

BigMac66
źródło
6
Niestety nie widzę tego w all browsers... nie działa w IE8, IE9 lub IE10 (ale działa w IE11).
freefaller
Cholera. Nie testowałem starszych wersji przeglądarki IE. Przepraszam.
BigMac66
31

Niestety żadna z powyższych odpowiedzi nie wydaje się obejmować wszystkich podstaw - przynajmniej nie w przypadku moich testów z javascriptem waniliowym.

  • .value = nullwydaje się działać na FireFox, Chome, Opera i IE11 (ale nie IE8 / 9/10 )

  • .cloneNode(i .clone()jQuery) na FireFox wydaje się kopiować .valueover, przez co klonowanie jest bezcelowe.

Oto napisana przeze mnie funkcja javascript vanilla, która działa na FireFox (27 i 28), Chrome (33), IE (8, 9, 10, 11), Opera (17) ... to są jedyne obecnie dostępne przeglądarki do mnie do przetestowania.

function clearFileInput(ctrl) {
  try {
    ctrl.value = null;
  } catch(ex) { }
  if (ctrl.value) {
    ctrl.parentNode.replaceChild(ctrl.cloneNode(true), ctrl);
  }
}

ctrlParametrem jest plik wejściowy sama, więc funkcja będzie wywoływana jako ...

clearFileInput(document.getElementById("myFileInput"));
freefaller
źródło
1
To jest odpowiedź. Jednym z problemów związanych z tak wieloma odpowiedziami na to pytanie - nie tylko na tej stronie, ale także na innych forach, jest to, że możesz wyczyścić tekst „3 wybrane pliki”, ale w rzeczywistości nie usuwa to plików http kolejka. Dzieje się tak, że przy następnej próbie przesłania możesz wybrać tylko jeden plik, a co gorsza, zostanie on zapisany w poprzednim folderze plików. Ta odpowiedź usunie oba i możesz wznowić przesyłanie następnego zestawu plików tak samo łatwo, jak przesłałeś pierwszy zestaw plików.
TARKUS
Czy ifoświadczenie nie powinno być umieszczone wewnątrz catchbloku?
Fahmi
@Fahmi - nie, nie powinno
freefaller
Aha myślałem, że IE8 / 9/10 wyrzuci wyjątek przy próbie ustawienia wartości na null. Masz ochotę wyjaśnić, jaki jest sens umieszczania ctrl.value = null;w try...catchbloku? Przepraszam za nowe pytanie.
Fahmi
1
ctrl.parentNode.replaceChild(ctrl.cloneNode(true), ctrl);- w którym momencie faktycznie usuwamy wartość, skoro cloneNoderównież ją kopiuje?
Fahmi
12

ROZWIĄZANIE

Poniższy kod działał dla mnie z jQuery. Działa w każdej przeglądarce i pozwala zachować zdarzenia i niestandardowe właściwości.

var $el = $('#your-input-id');
$el.wrap('<form>').closest('form').get(0).reset();
$el.unwrap();

PRÓBNY

Zobacz to jsFiddle aby uzyskać kod i demonstrację.

SPINKI DO MANKIETÓW

Gyrocode.com
źródło
11

Musisz go zastąpić nowym wejściem pliku. Oto, jak można to zrobić za pomocą jQuery:

var inputFile = $('input[type=field]');
inputFile.wrap('<div />');

i użyj tej linii, gdy chcesz wyczyścić pole wejściowe (na przykład w niektórych zdarzeniach):

inputFile.parent().html( inputFile.parent().html() );
Jamland
źródło
W przypadku wymiany oryginalnego elementu wygląda to lepiej: stackoverflow.com/questions/1043957/…
Mengdi Gao
9
document.getElementById('your_input_id').value=''

Edycja:
ten nie działa w IE i operze, ale wydaje się działać z przeglądarkami Firefox, Safari i Chrome.

Soufiane Hassou
źródło
7
U mnie to działa, chociaż zawsze zadaję sobie pytanie, na jak długo.
Pekka
to nie zadziała, tylko w niektórych przeglądarkach, a także ustawienie wartości pliku wejściowego jest naruszeniem bezpieczeństwa ... nie jest dobrym wyborem.
5

Miałem ten sam problem i wpadłem na to.

var file = document.querySelector('input');
var emptyFile = document.createElement('input');
emptyFile.type = 'file';

document.querySelector('button').onclick = function(){
  file.files = emptyFile.files;
}
<input type='file'>
<button>clear</button>

ajit kumar
źródło
4

To całkiem proste.

document.querySelector('#input-field').value = '';
anonim
źródło
3

Szukałem prostego i przejrzystego sposobu na wyczyszczenie danych wejściowych z pliku HTML, powyższe odpowiedzi są świetne, ale żadna z nich tak naprawdę nie odpowiada na to, czego szukam, dopóki nie znalazłem w Internecie prostego i eleganckiego sposobu na zrobienie tego:

var $input = $("#control");

$input.replaceWith($input.val('').clone(true));

cała zasługa Chrisa Coyiera .

// Referneces
var control = $("#control"),
    clearBn = $("#clear");

// Setup the clear functionality
clearBn.on("click", function(){
    control.replaceWith( control.val('').clone( true ) );
});

// Some bound handlers to preserve when cloning
control.on({
    change: function(){ console.log( "Changed" ) },
     focus: function(){ console.log(  "Focus"  ) }
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<input type="file" id="control">
<br><br>
<a href="#" id="clear">Clear</a>

chebaby
źródło
..i tobie, kolego, pomogło mi to przy sprawdzaniu i wyświetlaniu błędów w potencjalnym załadowaniu pliku. To resetuje się po błędzie i pozwala użytkownikowi ponownie przesłać ten sam plik na wypadek, gdyby ktoś szukał czegoś takiego.
Clinton Dobbs
1

Powyższe odpowiedzi oferują nieco niezdarne rozwiązania z następujących powodów:

  1. Nie lubię konieczności a potem coraz html, jest bardzo zaangażowany i brudne.wrapinput

  2. JS między przeglądarkami jest przydatny i wydaje się, że w tym przypadku jest zbyt wiele niewiadomych, aby niezawodnie używać typeprzełączania (które, znowu, jest trochę brudne) i ustawiania valuena''

Więc oferuję Ci moje rozwiązanie oparte na jQuery:

$('#myinput').replaceWith($('#myinput').clone())

Robi to, co mówi, zastępuje dane wejściowe klonem samego siebie. Klon nie będzie miał wybranego pliku.

Zalety:

  1. Prosty i zrozumiały kod
  2. Żadnego niezgrabnego owijania lub zmiany pisma
  3. Zgodność z różnymi przeglądarkami (popraw mnie, jeśli się mylę)

Wynik: szczęśliwy programista

Mosselman
źródło
3
Cross browser compatibility... moje testy pokazują, że FireFox kopiuje .valuejako część pliku .clone(), co czyni go bezużytecznym
freefaller
@freefaller, dlaczego nie zmienić wartości przed wywołaniem replaceWith? Używam clone()siebie i działa dobrze w przeglądarce Firefox (nie wiem, czy rok później nadal tak jest =))
Abdo
@Abdo - jeśli spojrzysz na moją odpowiedź , zobaczysz, że tak
freefaller
Pytanie nie dotyczy jQuery; pyta o javascript.
Arel
1

Oto moje dwa centy, pliki wejściowe są przechowywane jako tablice, więc oto jak je wyzerować

document.getElementById('selector').value = []

zwraca to pustą tablicę i działa we wszystkich przeglądarkach

Sam Hasan
źródło
0

Pomogło mi to, że zamiast wyczyścić kolejkę próbowałem pobrać i przesłać ostatni wybrany plik za pomocą pętli i zadziałało. Oto kod.

for (int i = 0; i <= Request.Files.Count-1; i++)
{
 HttpPostedFileBase uploadfile = files[i];
 Stream fs = uploadfile.InputStream;
 BinaryReader br = new BinaryReader(fs);
 Byte[] imageBytes = br.ReadBytes((Int32)fs.Length);
}

Mam nadzieję, że to może niektórym pomóc.

dotRag
źródło
0

Wypróbowałem większość rozwiązań, ale wydawało się, że nikt nie działa. Jednak poniżej znalazłem spacer.

Konstrukcja formy jest: form=> label, inputisubmit button . Po wybraniu pliku nazwa pliku zostanie wyświetlona obok etykiety, robiąc to ręcznie w JavaScript.

Więc moja strategia jest taka: początkowo przesyłanie buttonjest wyłączone, po wybraniu pliku disabledatrybut przycisku przesyłania zostanie usunięty, tak że mogę przesłać plik. Po przesłaniu wyczyszczę, labelco sprawia, że ​​wygląda na to, że wyczyściłem plik, inputale w rzeczywistości nie. Następnie ponownie wyłączę przycisk przesyłania, aby uniemożliwić przesłanie formularza.

Ustawiając przesyłanie button disablelub nie, zatrzymuję przesyłanie pliku wiele razy, chyba że wybiorę inny plik.

user419050
źródło
0

Zmieniłem wpisywanie tekstu i powrót do wpisywania do pliku za pomocą setAttribute

'<input file-model="thefilePic" style="width:95%;" type="file" name="file" id="filepicture" accept="image/jpeg" />'

'var input=document.querySelector('#filepicture');'

if(input != null)
{
    input.setAttribute("type", "text");
    input.setAttribute("type", "file");
}
Haiam
źródło