dropzone.js에서 기본 텍스트를 변경하려면 어떻게 해야 합니까?
dropzone.js를 사용하여 파일을 업로드하고 있습니다.하지만 기본 텍스트를 변경하는 데 어려움을 겪고 있습니다.
드롭존 클래스를 인스턴스화해 보았습니다.
$(document).ready(function(){
$(".foo").dropzone({ dictDefaultMessage: "hello" });
});
이 마크업을 통해:
<div class="span4">
<form action="http://localhost/post" method="post" accept-charset="utf-8" id="drop3" class="foo" enctype="multipart/form-data"> </form>
</div>
<div class="span4">
<form action="http://localhost/post" method="post" accept-charset="utf-8" id="drop4" class="foo" enctype="multipart/form-data"> </form>
</div>
이렇게 하면 파일을 업로드할 수 있지만 기본 텍스트는 공백입니다.
다음을 테스트했습니다.
$(".foo").dropzone();
기본 텍스트가 없는 동일한 결과를 얻은 것 같습니다.그럼.. 기본 텍스트를 변경하려면 어떻게 해야 합니까?
다음과 같이 드롭존 양식에 요소를 추가합니다.
<div class="dz-message" data-dz-message><span>Your Custom Message</span></div>
모든 기본 메시지를 다음과 같이 변경할 수 있습니다.
Dropzone.prototype.defaultOptions.dictDefaultMessage = "Drop files here to upload";
Dropzone.prototype.defaultOptions.dictFallbackMessage = "Your browser does not support drag'n'drop file uploads.";
Dropzone.prototype.defaultOptions.dictFallbackText = "Please use the fallback form below to upload your files like in the olden days.";
Dropzone.prototype.defaultOptions.dictFileTooBig = "File is too big ({{filesize}}MiB). Max filesize: {{maxFilesize}}MiB.";
Dropzone.prototype.defaultOptions.dictInvalidFileType = "You can't upload files of this type.";
Dropzone.prototype.defaultOptions.dictResponseError = "Server responded with {{statusCode}} code.";
Dropzone.prototype.defaultOptions.dictCancelUpload = "Cancel upload";
Dropzone.prototype.defaultOptions.dictCancelUploadConfirmation = "Are you sure you want to cancel this upload?";
Dropzone.prototype.defaultOptions.dictRemoveFile = "Remove file";
Dropzone.prototype.defaultOptions.dictMaxFilesExceeded = "You can not upload any more files.";
드롭존을 작성할 때 기본 메시지를 다음과 같이 설정할 수 있습니다.
var dropzone = new Dropzone("form.dropzone", {
dictDefaultMessage: "Put your custom message here"
});
그리고나서
$('div.dz-default.dz-message > span').show(); // Show message span
$('div.dz-default.dz-message').css({'opacity':1, 'background-image': 'none'});
먼저 양식에 ID를 추가합니다.mydz
, 다음 js를 추가합니다.
Dropzone.options.mydz = {
dictDefaultMessage: "your custom message"
};
전체 페이지(이 경우 index.php):
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<script src="dropzone.js"></script>
<link rel="stylesheet" type="text/css" href="./dropzone.css">
<title></title>
</head>
<body>
<form action="upload.php" class="dropzone" id="mydz"></form>
<script type="text/javascript">
Dropzone.options.mydz = {
dictDefaultMessage: "Put your custom message here"
};
</script>
</body>
</html>
이 텍스트는 드롭존의 기본 구성에 있으며 다음과 같이 덮어쓸 수 있습니다.
Dropzone.prototype.defaultOptions.dictDefaultMessage = "Your text";
myDropzonePhotos = new Dropzone('#dropzone-test',
{
url : 'upload_usuario.php?id_usuario=' + id_usuario,
maxFiles : 1,
thumbnailWidth : 1200,
thumbnailHeight : 300,
dictDefaultMessage : 'Change the text here!',
init: function()
{
....
몇 시간 동안 이걸 만지작거렸어요.
어떤 이유에서인지, 다음 세 가지 작업을 수행해야 했습니다.
- 내 드롭존 태그가 내가 드롭존을 사용하던 페이지에 있을 수 없습니다.템플릿 페이지에서 참조해야 했습니다.
- 드롭존으로 변환할 요소에는 '드롭존' 클래스가 있어야 합니다.
- 당신은 내가 작업하던 페이지의 js 파일 상단에 다음 내용을 추가해야 합니다.
Dropzone.autoDiscover = false;
초기화 방법:
var myDropzone = new Dropzone("#id-upload-dropzone", {
url: "/home/Upload",
dictDefaultMessage: 'Drop image here (or click) to capture/upload'
});
3개를 모두 순서대로 하면 dictDefaultMessage 옵션이 작동했습니다.
Asp에서 Dropzone의 로컬라이징을 위해 사용됩니다.Net Razor Pages 디코딩된 문자를 피하기 위해 다음 방법을 사용합니다.
모든 메시지에 대한 HTML 요소 작성
<!-- localization elements -->
<div class="modal" aria-hidden="true">
<span id="dictDefaultMessage">@_localizer["Drop files here or click to upload."]</span>
<span id="dictFallbackMessage">@_localizer["Your browser does not support drag'n'drop file uploads."]</span>
<span id="dictFallbackText">@_localizer["Please use the fallback form below to upload your files like in the olden days."]</span>
<span id="dictFileTooBig">@_localizer["File is too big ({{filesize}}MiB). Max filesize: {{maxFilesize}}MiB."]</span>
<span id="dictInvalidFileType">@_localizer["You can't upload files of this type."]</span>
<span id="dictResponseError">@_localizer["Server responded with {{statusCode}} code."]</span>
<span id="dictCancelUpload">@_localizer["Cancel upload"]</span>
<span id="dictCancelUploadConfirmation">@_localizer["Are you sure you want to cancel this upload?"]</span>
<span id="dictUploadCanceled">@_localizer["Upload canceled."]</span>
<span id="dictRemoveFile">@_localizer["Delete"]</span>
<span id="dictRemoveFileConfirmation">@_localizer["Are you sure you want to delete this file?"]</span>
<span id="dictMaxFilesExceeded">@_localizer["You can not upload any more files."]</span>
<span id="dictFileSizeUnits_TB">@_localizer["TB"]</span>
<span id="dictFileSizeUnits_GB">@_localizer["GB"]</span>
<span id="dictFileSizeUnits_MB">@_localizer["MB"]</span>
<span id="dictFileSizeUnits_KB">@_localizer["KB"]</span>
<span id="dictFileSizeUnits_b">@_localizer["b"]</span>
</div>
그런 다음 메시지를 Dropzone 요소에 바인딩합니다.
<script>
// get elements for localization
with (Dropzone.prototype.defaultOptions) {
dictDefaultMessage = document.getElementById("dictDefaultMessage").innerText;
dictFallbackMessage = document.getElementById("dictFallbackMessage").innerText;
dictFallbackText = document.getElementById("dictFallbackText").innerText;
dictFileTooBig = document.getElementById("dictFileTooBig").innerText;
dictInvalidFileType = document.getElementById("dictInvalidFileType").innerText;
dictResponseError = document.getElementById("dictResponseError").innerText;
dictCancelUpload = document.getElementById("dictCancelUpload").innerText;
dictCancelUploadConfirmation = document.getElementById("dictCancelUploadConfirmation").innerText;
dictUploadCanceled = document.getElementById("dictUploadCanceled").innerText;
dictRemoveFile = document.getElementById("dictRemoveFile").innerText;
dictRemoveFileConfirmation = document.getElementById("dictRemoveFileConfirmation").innerText; // if this is null, the user will not be prompted when deleting file.
dictMaxFilesExceeded = document.getElementById("dictMaxFilesExceeded").innerText;
dictFileSizeUnits = {
tb: document.getElementById("dictFileSizeUnits_TB").innerText,
gb: document.getElementById("dictFileSizeUnits_GB").innerText,
mb: document.getElementById("dictFileSizeUnits_MB").innerText,
kb: document.getElementById("dictFileSizeUnits_KB").innerText,
b: document.getElementById("dictFileSizeUnits_b").innerText
};
};
</script>
Dropzone을 사용한 전체 드래그 드롭 파일 업로드 샘플은 이 GitHub 저장소 https://github.com/LazZiya/FileUpload 를 참조하십시오.
드랍존의 CSS에서 다음을 찾습니다.
.dropzone .dz-default.dz-message
이 클래스에서 삭제
background-image: url("../images/spritemap.png");
다음으로 할 일은 이 수업을 검색하는 것입니다.
.dropzone .dz-default.dz-message span {
display: none;
}
표시로 변경합니다.블록
JQuery에 반대하지 않는 경우에는 기본 이미지가 숨겨집니다.
$('form.dropzone').find('div.default.message').css('background-image','none');
원하는 대로 변경할 수 있는 기본 스팬이 표시됩니다.
$('form.dropzone').find('div.default.message').find('span').show();
$('form.dropzone').find('div.default.message').find('span').empty();
$('form.dropzone').find('div.default.message').find('span').append('Drop files here or click here to upload an image.');
프로그램식으로 드롭존을 생성하는 경우 아래와 같은 옵션을 설정해야 합니다.
Dropzone.autoDiscover = false;
profilePicture = new Dropzone('#profile-picture', {
url: "/uploadPicture.php",
// if you are using laravel ..., you dont need to put csrf in meta tag
headers: {
'X-CSRF-TOKEN': "{{ csrf_token() }}"
},
dictDefaultMessage: "Your default message Will work 100%",
/other options
paramName: "profile_picture",
addRemoveLinks: true,
maxFilesize: 1,
maxFiles: 10,
dictRemoveFile: "Remove",
});
이렇게 사용하면 작동이 안 돼요.
let myDropzone = new Dropzone("#profile-picture", {
url: "/uploadPicture.php",
// if you are using laravel ..., you dont need to put csrf in meta tag
headers: {
'X-CSRF-TOKEN': "{{ csrf_token() }}"
},
});
myDropzone.options.profilePicture = {
dictDefaultMessage: "This message not gonna work",
paramName: "profile_picture",
};
언급URL : https://stackoverflow.com/questions/17702394/how-do-i-change-the-default-text-in-dropzone-js
'programing' 카테고리의 다른 글
안드로이드에서 수평 리스트뷰를 만들려면 어떻게 해야 합니까? (0) | 2023.09.24 |
---|---|
MySQL 및 1억 개 이상의 행이 있는 테이블 (0) | 2023.09.19 |
Chrome Back(크롬 뒤로) 버튼: 초기 페이지의 캐시된 버전만 제공하며, Ajaxed 콘텐츠는 없습니다. (0) | 2023.09.19 |
다른 시트 및 셀의 값을 기준으로 셀 색상 서식 지정 (0) | 2023.09.19 |
onclick () 및 onblur () 주문 문제 (0) | 2023.09.19 |