简体   繁体   English

选择文件时更改 Label 内容而不是 label 中的默认文本

[英]When File Selected Change Label Contents instead the default text in the label

So, I'm attempting to make my file upload input look a little bit better than the default buttons.所以,我试图让我的文件上传输入看起来比默认按钮好一点。 All is going well, however, I can't seem to find a jQuery script which can do what I want it to do.一切顺利,但是,我似乎找不到可以做我想做的事的 jQuery 脚本。

What I want to happen is, when a file isn't selected, I would like the label to display "Choisir le recto", but when a file is selected, I would like it to display the files name, ie: "example.png" instead of "Choisir le recto". What I want to happen is, when a file isn't selected, I would like the label to display "Choisir le recto", but when a file is selected, I would like it to display the files name, ie: "example. png”而不是“Choisir le recto”。

 $('input[type=file]').change(function() { var filename = $(this).val().split('\\').pop(); var idname = $(this).attr('id'); console.log($(this)); console.log(filename); console.log(idname); $('span.' + idname).next().find('span').html(filename); });
 .btnsend { display: block; visibility: hidden; position: absolute; }.labelbtn { color: #fff; display: inline-block; margin-bottom: 0; font-weight: normal; text-align: center; vertical-align: middle; -ms-touch-action: manipulation; touch-action: manipulation; cursor: pointer; background-color: #0057a0; border: 1px solid transparent; white-space: nowrap; padding: 6px 12px; font-size: 14px; line-height: 1.42857143; border-radius: 4px; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none }.labelbtn:hover { opacity: 0.8; background-color: #0072a0; }.sendall { margin-top: 30px; }
 <form method="POST" enctype="multipart/form-data"> <input type="file" name="recto" id="recto" class="btnsend" /> <label for="recto" class="labelbtn"><span> Choisir le Recto</span></label> <input type="file" name="verso" id="verso" class="btnsend" /> <label for="verso" class="labelbtn"><span>Choisir le Verso</span></label> <input type="file" name="selfie" id="selfie" class="btnsend" /> <label for="selfie" class="labelbtn"><span>Choisir le Selfie</span></label> <br> <input type="submit" name="submit" class="sendall">

The issue is due to the way you're attempting to find the relevant span in the DOM.问题是由于您尝试在 DOM 中查找相关span的方式。 You can just use the this keyword to refer to the input which raised the change event, then next() and find() from there:您可以只使用this关键字来引用引发change事件的input ,然后从那里使用next()find()

 $('input[type="file"]').on('change', function() { var filename = $(this).val().split('\\').pop(); $(this).next().find('span').html(filename); });
 .btnsend { display: block; visibility: hidden; position: absolute; }.labelbtn { color: #fff; display: inline-block; margin-bottom: 0; font-weight: normal; text-align: center; vertical-align: middle; -ms-touch-action: manipulation; touch-action: manipulation; cursor: pointer; background-color: #0057a0; border: 1px solid transparent; white-space: nowrap; padding: 6px 12px; font-size: 14px; line-height: 1.42857143; border-radius: 4px; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none }.labelbtn:hover { opacity: 0.8; background-color: #0072a0; }.sendall { margin-top: 30px; }
 <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.1/jquery.min.js"></script> <form method="POST" enctype="multipart/form-data"> <input type="file" name="recto" id="recto" class="btnsend" /> <label for="recto" class="labelbtn"><span>Choisir le Recto</span></label> <input type="file" name="verso" id="verso" class="btnsend" /> <label for="verso" class="labelbtn"><span>Choisir le Verso</span></label> <input type="file" name="selfie" id="selfie" class="btnsend" /> <label for="selfie" class="labelbtn"><span>Choisir le Selfie</span></label> <br> <input type="submit" name="submit" class="sendall" /> </form>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM