我想为图片上传制作自定义按钮.我可以通过下面的演示得到这个结果:
@H_502_2@https://jsfiddle.net/algometrix/fgrbyo4z/
@H_502_2@但我如何显示之后选择的文件名?或者甚至可能是图像的缩略图?就像我从弹出窗口的窗口中选择一个文件后,我希望它在我选择后在页面上显示“文件名”.
@H_502_2@Javascript – 如果有人可以在这方面提供帮助,jQuery完全是一个选项.
@H_502_2@HTML
<div> <div style="display:block;text-align:center;margin-top:20%;"> <label for="files"> <span class="btn">Select Image</span></label> <input style="visibility: hidden; position: absolute;" id="files" class="form-control" type="file" name="files"> </div> </div>@H_502_2@CSS
.btn { font-family: Arial; color: #ffffff; font-size: 20px; background: #3f88b8; padding: 10px 20px 10px 20px; text-decoration: none; } .btn:hover { background: #3cb0fd; background-image: -webkit-linear-gradient(top,#3cb0fd,#3498db); background-image: -moz-linear-gradient(top,#3498db); background-image: -ms-linear-gradient(top,#3498db); background-image: -o-linear-gradient(top,#3498db); background-image: linear-gradient(to bottom,#3498db); text-decoration: none; }
解决方法
通过添加javascript,我们可以在输入上查看更改事件,并将名称放在页面上.请注意这些次要的HTML更改:
<div class="file-upload"> <label for="upload-1" class="btn">Upload</label> <input type="file" id="upload-1"> <p class="file-name">Please select a file.</p> </div>@H_502_2@有了这个jQuery:
jQuery(function($) { $('input[type="file"]').change(function() { if ($(this).val()) { var filename = $(this).val(); $(this).closest('.file-upload').find('.file-name').html(filename); } }); });@H_502_2@Working Fiddle