jQuery : 선택한 파일 이름 가져 오기
이 코드는 IE에서 작동해야 하지만 (Firefox에서 테스트하지 마세요) 작동하지 않습니다. 내가 원하는 것은 첨부 파일의 이름을 표시하는 것입니다. 도움이 필요하세요?
<html>
<head>
<title>example</title>
<script type="text/javascript" src="../js/jquery.js"></script>
<script type="text/javascript">
$(document).ready( function(){
$("#attach").after("<input id='fakeAttach' type='button' value='attach a file' />");
$("#fakeAttach").click(function() {
$("#attach").click();
$("#maxSize").after("<div id='temporary'><span id='attachedFile'></span><input id='remove' type='button' value='remove' /></div>");
$('#attach').change(function(){
$("#fakeAttach").attr("disabled","disabled");
$("#attachedFile").html($(this).val());
});
$("#remove").click(function(e){
e.preventDefault();
$("#attach").replaceWith($("#attach").clone());
$("#fakeAttach").attr("disabled","");
$("#temporary").remove();
});
})
});
</script>
</head>
<body>
<input id="attach" type="file" /><span id="maxSize">(less than 1MB)</span>
</body>
</html>
다음과 같이 작성하는 것은 간단합니다.
$('input[type=file]').val()
어쨌든 이름 또는 ID 속성을 사용하여 입력을 선택하는 것이 좋습니다. 이벤트를 사용하면 다음과 같이 표시됩니다.
$('input[type=file]').change(function(e){
$in=$(this);
$in.next().html($in.val());
});
$('input[type=file]').change(function(e){
$(this).parents('.parent-selector').find('.element-to-paste-filename').text(e.target.files[0].name);
});
이 코드는 C:\fakepath\
을 사용하는 경우 Google 크롬에서 파일 이름 앞에 표시되지 않습니다 .val()
.
가장 간단한 방법은 간단히 다음 줄을 jquery
사용하는 것입니다.이 줄을 사용하면 /fakepath
말도 안되는 소리가 들리지 않고 업로드 된 파일을 바로 얻을 수 있습니다.
$('input[type=file]')[0].files[0]; // This gets the file
$('#idOfFileUpload')[0].files[0]; // This gets the file with the specified id
다른 유용한 명령은 다음과 같습니다.
파일 이름을 얻으려면 :
$('input[type=file]')[0].files[0].name; // This gets the file name
파일 유형을 가져 오려면 :
PNG를 업로드하면 image/png
$("#imgUpload")[0].files[0].type
파일 크기 (바이트)를 얻으려면 :
$("#imgUpload")[0].files[0].size
Also you don't have to use these commands on('change'
, you can get the values at any time, for instance you may have a file upload and when the user clicks upload
, you simply use the commands I listed.
<input onchange="readURL(this);" type="file" name="userfile" />
<img src="" id="blah"/>
<script>
function readURL(input) {
if (input.files && input.files[0]) {
var reader = new FileReader();
reader.onload = function (e) {
$('#blah')
.attr('src', e.target.result)
.width(150).height(200);
};
reader.readAsDataURL(input.files[0]);
//console.log(reader);
//alert(reader.readAsDataURL(input.files[0]));
}
}
</script>
I had used following which worked correctly.
$('#fileAttached').attr('value', $('#attachment').val())
//get file input
var $el = $('input[type=file]');
//set the next siblings (the span) text to the input value
$el.next().text( $el.val() );
Add a hidden reset button :
<input id="Reset1" type="reset" value="reset" class="hidden" />
Click the reset button to clear the input.
$("#Reset1").click();
<input onchange="readURL(this);" type="file" name="userfile" />
<img src="" id="viewImage"/>
<script>
function readURL(fileName) {
if (fileName.files && fileName.files[0]) {
var reader = new FileReader();
reader.onload = function (e) {
$('#viewImage')
.attr('src', e.target.result)
.width(150).height(200);
};
reader.readAsDataURL(fileName.files[0]);
}
}
</script>
참고URL : https://stackoverflow.com/questions/1299052/jquery-get-the-file-name-selected-from-input-type-file
'code' 카테고리의 다른 글
$ scope와 $ rootScope의 차이점 (0) | 2020.09.09 |
---|---|
Python으로 UTF8 CSV 파일 읽기 (0) | 2020.09.09 |
상수 목록의 인라인 인스턴스화 (0) | 2020.09.09 |
.NET 콘솔에서 JSON WebService를 호출하는 가장 좋은 방법 (0) | 2020.09.09 |
"gdb가 코드 서명되었는지 확인하십시오-taskgated (8) 참조"-홈브류 코드 서명으로 gdb를 설치하는 방법은 무엇입니까? (0) | 2020.09.09 |