이미지를 Base64로 변환
<input type="file" id="asd"/>
사용자가 그것을 선택하면 (양식을 제출하기 전에) base64에 있는 이미지를 받고 싶습니다.
다음과 같은 것:
$(input).on('change',function(){
var data = $(this).val().base64file(); // it is not a plugin is just an example
alert(data);
});
File API 및 기타 사항에 대해 읽었습니다. 간단한 크로스 브라우저 솔루션을 원합니다(IE6/IE7은 분명히 제외됨).
어떤 도움이든 감사합니다.
function readFile() {
if (!this.files || !this.files[0]) return;
const FR = new FileReader();
FR.addEventListener("load", function(evt) {
document.querySelector("#img").src = evt.target.result;
document.querySelector("#b64").textContent = evt.target.result;
});
FR.readAsDataURL(this.files[0]);
}
document.querySelector("#inp").addEventListener("change", readFile);
<input id="inp" type="file">
<p id="b64"></p>
<img id="img" height="150">
(P.S: Base64 인코딩 이미지 (String) 원본 이미지 데이터의 4/3 크기
브라우저 지원: http://caniuse.com/ #search=file%20api
자세한 내용은 https://developer.mozilla.org/en-US/docs/Web/API/FileReader 에서 확인할 수 있습니다.
정확히 필요한 것:) 콜백 버전 또는 Promise 버전을 선택할 수 있습니다.IE에서는 Promise polyfill lib로만 약속이 작동합니다.이 코드를 페이지에 한 번 넣으면 모든 파일에 이 기능이 나타납니다.
리소스 로드 진행이 중지된 경우(예: "오류", "중단" 또는 "로드"가 발송된 후) 로드 종료 이벤트가 발생합니다.
콜백 버전
File.prototype.convertToBase64 = function(callback){
var reader = new FileReader();
reader.onloadend = function (e) {
callback(e.target.result, e.target.error);
};
reader.readAsDataURL(this);
};
$("#asd").on('change',function(){
var selectedFile = this.files[0];
selectedFile.convertToBase64(function(base64){
alert(base64);
})
});
약속 버전
File.prototype.convertToBase64 = function(){
return new Promise(function(resolve, reject) {
var reader = new FileReader();
reader.onloadend = function (e) {
resolve({
fileName: this.name,
result: e.target.result,
error: e.target.error
});
};
reader.readAsDataURL(this);
}.bind(this));
};
FileList.prototype.convertAllToBase64 = function(regexp){
// empty regexp if not set
regexp = regexp || /.*/;
//making array from FileList
var filesArray = Array.prototype.slice.call(this);
var base64PromisesArray = filesArray.
filter(function(file){
return (regexp).test(file.name)
}).map(function(file){
return file.convertToBase64();
});
return Promise.all(base64PromisesArray);
};
$("#asd").on('change',function(){
//for one file
var selectedFile = this.files[0];
selectedFile.convertToBase64().
then(function(obj){
alert(obj.result);
});
});
//for all files that have file extention png, jpeg, jpg, gif
this.files.convertAllToBase64(/\.(png|jpeg|jpg|gif)$/i).then(function(objArray){
objArray.forEach(function(obj, i){
console.log("result[" + obj.fileName + "][" + i + "] = " + obj.result);
});
});
})
html
<input type="file" id="asd" multiple/>
<input type="file" onchange="getBaseUrl()">
function getBaseUrl () {
var file = document.querySelector('input[type=file]')['files'][0];
var reader = new FileReader();
var baseString;
reader.onloadend = function () {
baseString = reader.result;
console.log(baseString);
};
reader.readAsDataURL(file);
}
이 경우 지연된 개체로 작업하고 약속을 반환하는 것이 유용합니다.
function readImage(inputElement) {
var deferred = $.Deferred();
var files = inputElement.get(0).files;
if (files && files[0]) {
var fr= new FileReader();
fr.onload = function(e) {
deferred.resolve(e.target.result);
};
fr.readAsDataURL( files[0] );
} else {
deferred.resolve(undefined);
}
return deferred.promise();
}
위의 기능은 다음과 같은 방식으로 사용할 수 있습니다.
var inputElement = $("input[name=file]");
readImage(inputElement).done(function(base64Data){
alert(base64Data);
});
또는 당신의 경우:
$(input).on('change',function(){
readImage($(this)).done(function(base64Data){ alert(base64Data); });
});
jquery를 사용하여 영상을 base64로 변환하는 기능(vanila js로 변환할 수 있음).도움이 되길 바랍니다!
용도: input is your nameId 입력에 파일 이미지가 있습니다.
<input type="file" id="asd"/>
<button onclick="proccessData()">Submit</button>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script>
async function converImageToBase64(inputId) {
let image = $('#'+inputId)[0]['files']
if (image && image[0]) {
const reader = new FileReader();
return new Promise(resolve => {
reader.onload = ev => {
resolve(ev.target.result)
}
reader.readAsDataURL(image[0])
})
}
}
async function proccessData() {
const image = await converImageToBase64('asd')
console.log(image)
}
</script>
예: convertImageToBase64('yourFileInputId')
https://codepen.io/mariohandsome/pen/yLadmVb
// https://developer.mozilla.org/en-US/docs/Web/API/FileReader/readAsDataURL
/* Simple */
function previewImage( image, preview, string )
{
var preview = document.querySelector( preview );
var fileImage = image.files[0];
var reader = new FileReader();
reader.addEventListener( "load", function() {
preview.style.height = "100";
preview.title = fileImage.name;
// convert image file to base64 string
preview.src = reader.result;
/* --- */
document.querySelector( string ).value = reader.result;
}, false );
if ( fileImage )
{
reader.readAsDataURL( fileImage );
}
}
document.querySelector( "#imageID" ).addEventListener( "change", function() {
previewImage( this, "#imagePreviewID", "#imageStringID" );
} )
/* Simple || */
<form>
File Upload: <input type="file" id="imageID" /><br />
Preview: <img src="#" id="imagePreviewID" /><br />
String base64: <textarea id="imageStringID" rows="10" cols="50"></textarea>
</form>
최신 브라우저용(IE 지원 없음)
HTML 파일 입력
<style>
.upload-button {
background-color: grey;
}
.upload-button input{
display:none;
}
</style>
<label for="upload-photo" class="upload-button">
Upload file
<input
type="file"
id="upload-photo"
</input>
</label>
제이에스
document.getElementById("upload-photo").addEventListener("change", function({target}){
if (target.files && target.files.length) {
try {
const uploadedImageBase64 = await convertFileToBase64(target.files[0]);
//do something with above data string
} catch() {
//handle error
}
}
})
function convertFileToBase64(file) {
return new Promise((resolve, reject) => {
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = () => resolve(reader.result);
reader.onerror = reject;
});
}
const FR = new FileReader();
FR.addEventListener("load", function(evt) {
document.querySelector("#img").src = evt.target.result;
document.querySelector("#b64").`textContent` = evt.target.result;
});
FR.readAsDataURL(this.files[0]);
< img id="inp" src="https://tlc.ca/pricing-tool/images/logo.png">
<p id="b64"></p>
<img id="img" height="150">
- 리스트 항목
언급URL : https://stackoverflow.com/questions/17710147/image-convert-to-base64
'programing' 카테고리의 다른 글
wcf를 사용하여 SQL 서버에 대한 쿼리를 실행할 때 이상한 오류가 발생함 (0) | 2023.09.03 |
---|---|
MariaDB가 odbc.ini의 DSN에 연결합니다. (0) | 2023.09.03 |
Angular 2 + Typescript + systemjs 앱을 실제로 배포하려면 어떻게 해야 합니까? (0) | 2023.09.03 |
JavaScript에서 인라인 이벤트 처리기에 이벤트를 인수로 전달하는 방법은 무엇입니까? (0) | 2023.09.03 |
이 HTML에서 3D는 무엇을 하고 있습니까? (0) | 2023.09.03 |