Bootstrap 4 вход файла не показывает имя файла
У меня проблема с классом ввода пользовательского файла в Bootstrap 4.
после того, как я выбрал, какой файл я хочу загрузить, имя файла не отображается.
Я использую этот код:
<div class="input-group mb-3">
<div class="custom-file">
<input type="file" class="custom-file-input" id="inputGroupFile02">
<label class="custom-file-label" for="inputGroupFile02">Choose file</label>
</div>
<div class="input-group-append">
<button class="btn btn-primary">Upload</button>
</div>
</div>
Любая идея, как я могу исправить это, не становясь слишком сложным?
Ответы
Ответ 1
Вам нужно использовать javascript для отображения имени выбранного файла, как указано в документации: https://v4-alpha.getbootstrap.com/components/forms/#file-browser
Здесь вы можете найти решение: Bootstrap 4 Вход в файл
UPDATE:
Что код для вашего примера:
<html lang="en">
<head>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
<script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script>
</head>
<body>
<div class="input-group mb-3">
<div class="custom-file">
<input type="file" class="custom-file-input" id="inputGroupFile02"/>
<label class="custom-file-label" for="inputGroupFile02">Choose file</label>
</div>
<div class="input-group-append">
<button class="btn btn-primary">Upload</button>
</div>
</div>
<script>
$('#inputGroupFile02').on('change',function(){
//get the file name
var fileName = $(this).val();
//replace the "Choose a file" label
$(this).next('.custom-file-label').html(fileName);
})
</script>
</body>
</html>
Ответ 2
Я использовал следующие для этого:
<script type="application/javascript">
$('input[type="file"]').change(function(e){
var fileName = e.target.files[0].name;
$('.custom-file-label').html(fileName);
});
</script>
Ответ 3
Ответ Anuja Patil работает только с одним входным файлом на странице. Это работает, если их больше одного. Этот фрагмент также отображает все файлы, если разрешено multiple
.
<script type="text/javascript">
$('.custom-file input').change(function (e) {
var files = [];
for (var i = 0; i < $(this)[0].files.length; i++) {
files.push($(this)[0].files[i].name);
}
$(this).next('.custom-file-label').html(files.join(', '));
});
</script>
Обратите внимание, что $(this).next('.custom-file-label').html($(this)[0].files.join(', '));
не работает. Вот почему цикл for
нужен.
Если вы никогда не работаете с файлами mulitple при загрузке файла, этот простой фрагмент можно использовать.
<script type="text/javascript">
$('.custom-file input').change(function (e) {
$(this).next('.custom-file-label').html(e.target.files[0].name);
});
</script>
Ответ 4
Если вы хотите, вы можете использовать рекомендуемый плагин Bootstrap для динамического ввода пользовательского файла: https://www.npmjs.com/package/bs-custom-file-input
Этот плагин может использоваться с jQuery или без него и работает с React an Angular
Ответ 5
Этот код работает для меня:
<script type="application/javascript">
$('#elementID').change(function(event){
var fileName = event.target.files[0].name;
if (event.target.nextElementSibling!=null){
event.target.nextElementSibling.innerText=fileName;
}
});
</script>
Ответ 6
Когда у вас несколько файлов, идея состоит в том, чтобы показать только первый файл и количество скрытых имен файлов.
$('.custom-file input').change(function() {
var $el = $(this),
files = $el[0].files,
label = files[0].name;
if (files.length > 1) {
label = label + " and " + String(files.length - 1) + " more files"
}
$el.next('.custom-file-label').html(label);
});