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();
}
'js' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[JavaScript] file drag and drop (0) | 2023.12.11 |
---|---|
for in ๋ฌธ ์ฌ์ฉ ์ ์ฃผ์ํ ์ (2) | 2023.12.08 |
ํธ๋ฆฌ๊ตฌ์กฐ jsTree ์ฌ์ฉํด๋ณด๊ธฐ (2) | 2023.12.07 |
<optgroup> select box ๊ทธ๋ฃนํ (2) | 2023.12.05 |
[jQuery] $.isNumeric() ์ซ์ ํ์ธ ํจ์ (0) | 2022.04.29 |