js
[JavaScript] jSignature.min.js μ¬μ©νμ¬ μ μ μλͺ κΈ°λ₯ κ°λ°
natrue
2024. 4. 29. 13:27
728x90
jSignatureλ λΈλΌμ°μ μ°½μμ μλͺ μΊ‘μ² νλ μμ±μ λ¨μννμ¬ μ¬μ©μκ° λ§μ°μ€,
ν λλ μκ°λ½μ μ¬μ©νμ¬ μλͺ μ 그릴 μ μλλ‘ νλ JavaScript μμ ―(jQuery νλ¬κ·ΈμΈ)
<script src="https://cdn.cdnhub.io/jSignature/2.1.3/jSignature.min.js"></script>
html μμ€
<div class="f_name_area">
<ul>
<li>
<p class="name" >νμ 0 : <span id="signNm1"></span> </p>
<button type="button" class= "sign_button" onclick="openSignatureModal('signNm1', '1', this); ">
<label for="name1">
<span>μλͺ
</span>
<img src="" id="signNm1_img" class="signature-img" alt="">
</label>
</button>
<button style="display:none;" type="button" onclick="deleteSignature('signNm1', '1', this);" class="sign_Delbutton" id="signNm1_del"><img src="/images/common/ico_close.svg" alt="μλͺ
μμ "></button>
</li>
<li>
<p class="name" >νμ 1 : <span id="signNm2"></span> </p>
<button type="button" class= "sign_button" onclick="openSignatureModal('signNm2', '2', this); ">
<label for="name1">
<span>μλͺ
</span>
<img src="" id="signNm2_img" class="signature-img" alt="">
</label>
</button>
<button style="display:none;" type="button" onclick="deleteSignature('signNm2', '1', this);" class="sign_Delbutton" id="signNm2_del"><img src="/images/common/ico_close.svg" alt="μλͺ
μμ "></button>
</li>
<li>
<p class="name" >νμ 2 : <span id="signNm3"></span> </p>
<button type="button" class= "sign_button" onclick="openSignatureModal('signNm3', '3', this); ">
<label for="name1">
<span>μλͺ
</span>
<img src="" id="signNm3_img" class="signature-img" alt="">
</label>
</button>
<button style="display:none;" type="button" onclick="deleteSignature('signNm3', '1', this);" class="sign_Delbutton" id="signNm3_del"><img src="/images/common/ico_close.svg" alt="μλͺ
μμ "></button>
</li>
<li>
<p class="name" >νμ 3 : <span id="signNm4"></span> </p>
<button type="button" class= "sign_button" onclick="openSignatureModal('signNm4', '4', this); ">
<label for="name1">
<span>μλͺ
</span>
<img src="" id="signNm4_img" class="signature-img" alt="">
</label>
</button>
<button style="display:none;" type="button" onclick="deleteSignature('signNm4', '1', this);" class="sign_Delbutton" id="signNm4_del"><img src="/images/common/ico_close.svg" alt="μλͺ
μμ "></button>
</li>
<li>
<p class="name" >νμ 4 : <span id="signNm5"></span> </p>
<button type="button" class= "sign_button" onclick="openSignatureModal('signNm5', '5', this); ">
<label for="name1">
<span>μλͺ
</span>
<img src="" id="signNm5_img" class="signature-img" alt="">
</label>
</button>
<button style="display:none;" type="button" onclick="deleteSignature('signNm5', '1', this);" class="sign_Delbutton" id="signNm5_del"><img src="/images/common/ico_close.svg" alt="μλͺ
μμ "></button>
</li>
</ul>
</div>
<div class="layer_wrap" style="display: none;">
<div class="layer_popup">
<div class="popup_header">
<div class="title_wrap">
<h3>μλͺ
λ : λ§μ°μ€λ‘ μ
λ ₯νμΈμ.</h3>
</div>
</div>
<div class="popup_con">
<div id="signatureparent">
<div id="signature"></div>
<div class="btn_wrap">
<button onclick="saveSignature(); return false;" class="btn btn_a">μ μ₯</button>
<button onclick="closeSignature(); return false;" class="btn btn_b">λ«κΈ°</button>
</div>
</div>
</div>
</div>
</div>
js μμ€
var currentSignId;
var currentNum;
// μλͺ
λͺ¨λ¬ μ΄κΈ° ν¨μ
function openSignatureModal(spanId, num, clickedButton) {
// λ€λ₯Έ λ²νΌμ λΉνμ±ν
var buttons = document.querySelectorAll('.sign_button');
buttons.forEach(function(button) {
if (button !== clickedButton) {
button.disabled = true;
}
});
$("#signatureparent").show();
$(".layer_wrap").css("display","flex");
// μ΄λ―Έμ§κ° λΉμ΄μλ κ²½μ° μ΄κΈ°ν
if ($("#" + spanId + "_img").attr("src") == '') {
$("#signature").jSignature({"decor-color": "transparent"});
} else {
clearSignature();
$("#signature").jSignature({"decor-color": "transparent"});
}
currentSignId = spanId; // νμ¬ ID μ€μ
currentNum = num; // νμ¬ μ«μ μ€μ
}
// sign κ΄λ ¨ λ²νΌ νμ±ν
function button_disabled_false() {
var buttons = document.querySelectorAll('.sign_button');
buttons.forEach(function(button) {
button.disabled = false;
});
}
function saveSignature() {
// μλͺ
λ°μ΄ν° κ°μ Έμ€κΈ°
var data = $("#signature").jSignature("getData", "image");
var imgSrc = "data:" + data[0] + "," + data[1];
// ** μ΄λ―Έμ§ μμ€ μ€μ
$("#" + currentSignId + "_img").attr("src", imgSrc);
$("#" + currentSignId +"_del").css("display", "block");
$("#signatureparent").hide();
$(".layer_wrap").hide();
removeSignature();
button_disabled_false(); // λͺ¨λ λ²νΌ νμ±ν
}
function deleteSignature(spanId, num, clickedButton) {
$("#"+ spanId +"_img").attr("src","");
$("#" + spanId +"_del").css("display", "none");
}
function removeSignature() {
if (currentNum >= 0) {
for (var i = 0; i < currentNum.length; i++) {
$("#signature .jSignature")[i].remove();
}
}
}
function clearSignature() {
for (var i = 1; i < $("#signature .jSignature").length; i++) {
$("#signature .jSignature")[i].remove();
}
}
function closeSignature() {
$("#signatureparent").hide();
$(".layer_wrap").hide();
removeSignature();
button_disabled_false();
}


