728x90

Select elements typically have two values that you want to access. First there's the value to be sent to the server, which is easy:

1
2
$( "#myselect" ).val();
// => 1

The second is the text value of the select. For example, using the following select box:

1
2
3
4
5
6
7
<select id="myselect">
<option value="1">Mr</option>
<option value="2">Mrs</option>
<option value="3">Ms</option>
<option value="4">Dr</option>
<option value="5">Prof</option>
</select>

If you wanted to get the string "Mr" if the first option was selected (instead of just "1") you would do that in the following way:

1
2
$( "#myselect option:selected" ).text();
// => "Mr"


728x90

jquery를 이용하여 checkbox 핸들링 테스트를 해보았다.


  • 체크 박스 전체 석택
  • 체크 박스 전체 해제
  • 체크 되어 있는 값 추출
  • 서버에서 받아온 데이터 체크하기 (콤마로 받아온 경우)


<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=EUC-KR">

<title>Insert title here</title>

<script type="text/javascript" src="http://code.jquery.com/jquery-1.8.1.min.js"></script>

<script type="text/javascript">


$(document).ready(function() {


// 체크 박스 모두 체크

$("#checkAll").click(function() {

$("input[name=box]:checkbox").each(function() {

$(this).attr("checked", true);

});

});


// 체크 박스 모두 해제

$("#uncheckAll").click(function() {

$("input[name=box]:checkbox").each(function() {

$(this).attr("checked", false);

});

});


// 체크 되어 있는 값 추출

$("#getCheckedAll").click(function() {

$("input[name=box]:checked").each(function() {

var test = $(this).val();

console.log(test);

});

});


// 서버에서 받아온 데이터 체크하기 (콤마로 받아온 경우)

$("#updateChecked").click(function() {

var splitCode = $("#splitCode").val().split(",");

for (var idx in splitCode) {

$("input[name=box][value=" + splitCode[idx] + "]").attr("checked", true);

}

});


// test case

test1();


});


function test1() {


console.log("################################################");

console.log("## test1 START");

console.log("################################################");


var cnt = $("input:checkbox").size();

console.log("checkboxSize=" + cnt);


$("input[name=box]:checkbox").each(function() {

var checkboxValue = $(this).val();

console.log("checkboxValue=" + checkboxValue);

});


console.log("----------------------------------------------");


$("#checkboxArea").children().each(function() {

var checkboxValue = $(this).children(":checkbox").val();

var text = $(this).children().eq(1).text();

console.log(text + "=" + checkboxValue);

});

}


</script>

</head>

<body>


<div id="checkboxArea">

<li><input type="checkbox" name="box" value="A" /><label>1번째 checkbox</label></li>

<li><input type="checkbox" name="box" value="B" /><label>2번째 checkbox</label></li>

<li><input type="checkbox" name="box" value="C" /><label>3번째 checkbox</label></li>

<li><input type="checkbox" name="box" value="D" /><label>4번째 checkbox</label></li>

</div>


<br/><br/>


<div id="buttonGroups">

<input type="button" id="checkAll" value="check all" />

<input type="button" id="uncheckAll" value="uncheck all" />

<input type="button" id="getCheckedAll" value="get checked all" />

<input type="button" id="updateChecked" value="updateChecked" />

</div>


<input type="hidden" id="splitCode" name="splitCode" value="A,C,D" />


</body>

</html>


한 가지 고민스러운 것은 서버에서 받아온 데이터가 콤마가 아닌 리스트 형태일 경우 어떻게 처리하는 것이 좋을까 이다.


service layer에서 리스트 형태의 checkbox 데이터를 콤마 형태로 가공한 후 view에 던져줘야 할까?

아니면 리스트로 받은 데이터를 view에 던져주어 데이터 가공 작업을 위임할까?


okjsp에 질문올려서 다른 분들은 어떤 방법을 사용하고 있는지 알아봐야 겠다.



728x90

 일명 버그라고 알려져 있고, CSS를 사용할 때 수없이 사용되는 필수 학습해야 하는 코드입니다.


 왜 클리어픽스를 사용해야 하는지 먼저 알아볼까요?



 HTML 문서 구조에서 부모 요소가 자식 요소를 감싸고 있을 때, 자식 요소에게 float 형식을 적용하면 부모 요소가 자식 요소를 더 이상 감싸지 않게되고 높이 값을 파악하지 못하게 되는 버그가 발생합니다. 따라서 부모 요소의 높이 값이 0px로 출력되고, 전체적인 HTML 요소들이 뒤엉켜버리는 경우가 많습니다. 


 이 때 부모 요소가 다시 자식 요소를 감쌀 수 있게 float을 초기화(clear) 하여 버그를 고쳐주는(fix) 코드가 필요한데 이것을 clearfix라고 합니다.


 다양한 방법이 있는데, 저는 항상 이 코드를 사용합니다.


 마이크로 클리어픽스(Micro Clearfix)라고 불리구요. 코드가 가장 간결합니다.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
/**
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    contenteditable attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that are clearfixed.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */
.cf:before,
.cf:after {
    content" "/* 1 */
    display: table; /* 2 */
}
 
.cf:after {
    clearboth;
}
 
/**
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */
.cf {
    *zoom: 1;
}

출처: http://nicolasgallagher.com/micro-clearfix-hack/


 IE6, 7은 거의 사용되지 않으니 젤 하단의 코드는 사실 필요 없습니다.

 제가 강조시킨 부분만 해당 div 등의 요소에 .cf를 추가시키거나 상위 코드에 .cf를 해당 요소의 클래스 값으로 수정하셔도 상관 없습니다.


 사실 float은 클리어픽스 등 사용방법의 민감함 등으로 인해 저같은 경우는 잘 사용하지 않고, 사실 부모 요소에 position: relative;를 주고 자식 요소에 position: absolute;를 줘서 top: 10px; left: 20px; 이런 식으로 CSS를 짜는 경우가 많습니다.


 꽤 중요한 코드인데 팁 게시판에 없길래 올려봅니다. 이 글 보관 해두셨다가 필요하실 때마다 사용하시길!!

'WEB' 카테고리의 다른 글

[PHP] addslashes  (0) 2018.01.24
자바스크립트(Javascript) 소수점 자리수, 올림, 버림, 반올림, 원단위 절사  (0) 2018.01.24
[PHP] swtich  (0) 2018.01.23
How to use PHP string in mySQL LIKE query?  (0) 2018.01.22
explode  (0) 2018.01.22
728x90

Javascript나 JQuery를 사용하여 페이지에 숫자를 출력해주어야 되는 경우를 자주 만나게 되실 텐데요~

 

보통 DB에서 숫자를 받아오거나 또는 산술 연산 결과를 화면에 찍어주게 되는데, 단순히 숫자만을 찍어주는 것보다는 3자리 단위마다 콤마(,)를 찍어주게 되면 훨씬 가독성이 좋아집니다. (숫자 천단위마다 콤마 찍기)

 

-> 352930203 (3억5천2백9십3만2백3)

 

-> 352,930,203 

 

 

어떤게 보기 쉽고, 잘 읽혀지시나요?^^

거의 대부분의 경우 두 번째가 쉽게 읽혀집니다. 

 

 

그래서 대부분의 웹 서비스(특히 일반 사용자들이 많고, 숫자를 자주 표기하는 서비스)는 숫자를 표시할 때, 3자리마다 콤마로 찍어서 표시하여 주는 경우가 대부분인데요.

 

그럼 콤마는 텍스트인데, 숫자를 어떻게 구분하여 텍스트인 콤마를 사이사이에 넣어주는 것일까요? 간단하게 처리하는 방법이 없을까요?

사실 숫자는 산술 연산이나 비교 연산 시에서 숫자로써 의미가 있을 뿐이고, 최종적으로 화면에 출력되는 숫자는 텍스트로 보셔도 무방합니다.

 

그렇기 때문에 숫자에 콤마를 붙이는 방법은 단순히 숫자를 텍스트로 변환하고, 3자리마다 콤마를 삽입해 주는 작업만 해 주면 됩니다.^^

 

 

 

방법1. (방법1 코드는 여러 블로그에서 많이 참조되어 사용되고 있는 코드입니다.)

 

 * 소스 코드 내에 이해를 돕기 위한 주석을 작성하였습니다.

 * 코드 하단에도 추가 이해를 돕기 위한 코드 설명을 작성하였습니다.

 

function AddComma(data_value) {

 

    var txtNumber = '' + data_value;    // 입력된 값을 문자열 변수에 저장합니다.

 

    if (isNaN(txtNumber) || txtNumber == "") {    // 숫자 형태의 값이 정상적으로 입력되었는지 확인합니다.
        alert("숫자만 입력 하세요");
        return;
    }

    else {
        var rxSplit = new RegExp('([0-9])([0-9][0-9][0-9][,.])');    // 정규식 형태 생성
        var arrNumber = txtNumber.split('.');    // 입력받은 숫자를 . 기준으로 나눔. (정수부와 소수부분으로 분리)
        arrNumber[0] += '.'; // 정수부 끝에 소수점 추가

 

        do {
            arrNumber[0] = arrNumber[0].replace(rxSplit, '$1,$2'); // 정수부에서 rxSplit 패턴과 일치하는 부분을 찾아 replace 처리
        } while (rxSplit.test(arrNumber[0])); // 정규식 패턴 rxSplit 가 정수부 내에 있는지 확인하고 있다면 true 반환. 루프 반복.

 

        if (arrNumber.length > 1) { // txtNumber를 마침표(.)로 분리한 부분이 2개 이상이라면 (즉 소수점 부분도 있다면)
            return arrNumber.join(''); // 배열을 그대로 합칩. (join 함수에 인자가 있으면 인자를 구분값으로 두고 합침)
        }
        else { // txtNumber 길이가 1이라면 정수부만 있다는 의미.
            return arrNumber[0].split('.')[0]; // 위에서 정수부 끝에 붙여준 마침표(.)를 그대로 제거함.
        }
    }
}

 

 * data_value 는 콤마를 붙일 숫자 텍스트입니다.

 

 * var rxSplit = RegExp('([0-9])([0-9][0-9][0-9][,.])') 정규식 패턴을 생성합니다.

   - [0-9] 는 0에서 9사이의 값 중에 하나가 올 수 있음.

   - [,.] 는 콤마(,) 또는 마침표(.) 중 하나가 올 수 있음

   - () 는 여러 개의 식을 하나로 묶기 위해서 사용 ([0-9][0-9][0-9][,.]) 는 xxx, or xxx. 형태의 값이 나오는 패턴. (x는 숫자 하나)

   - ([0-9])([0-9][0-9][0-9][,.]) 는 결국 xxxx, xxxx. 의 패턴을 의미함 (x는 숫자 하나) 굳이 하위식(괄호()) 2개로 분리하여 숫자를 표기한 이유는 그 사이에 콤마을 삽입하기 위함.

 

 * arrNumber[0] = arrNumber[0].replace(rxSplit, '$1,$2');

  - 정수부에서 rxSplit(패턴 : '([0-9])([0-9][0-9][0-9][,.])')과 일치하는 부분을 찾아서 $1 과 $2로 대체.

    여기서 $1 과 $2 는 패턴의 1번 하위식, 2번 하위식을 의미. 하위식은 괄호 () 부분을 의미함. 즉 ([0-9]) = $1, ([0-9][0-9][0-9][,.]) = $2 를 뜻함.

    $1과 $2 사이에 콤마가 있으므로 숫자 4개가 연속하고, 끝에 콤마(,) 또는 마침표(.) 의 패턴을 가지는 숫자인 경우 X,XXX 형태로 대체(Replace) 함.

 

 

 <참고> 자세한 정규 표현식 문법은 여기를 참조하세요~

   참조 URL : http://ko.wikipedia.org/wiki/%EC%A0%95%EA%B7%9C_%ED%91%9C%ED%98%84%EC%8B%9D

 

뭔가 코드가 난해하기도 하고, 정규식 패턴도 나오고, 조금 어려워 보이실 수도 있습니다.

하지만, 하나하나 코드를 분석해 보시면 어떻게 처리가 되는지 크게 어렵지 않게 이해하실 수 있습니다.

 

일단 코드는 잘 동작합니다만. 방법 2번을 보시게 되신다면 내가 왜 이 코드를 보고 있었나 하실 수도 있겠습니다.^^

그래도 다양한 함수 사용법에 대해 알 수 있었고, 특히 정규식에 대한 이해는 중요합니다.

 

 

 

방법2.

 

function AddComma(data_value) {

return Number(data_value).toLocaleString('en');

}

 

 

 참 쉽죠~ 간단합니다. 위에서 십여줄에 작성하여 얻어내었던 결과를 단 한줄로 처리하였습니다.

 

 * toLocaleString 은 Number 타입의 내장 함수이며, 인자로 들어온 지역 값에 따른 숫자 표기 방식을 적용하여, 문자열로 반환하는 역할을 합니다. 'en'은 영어권 국가의 숫가 표기 방식을 사용하겠다는 것을 지정한 것입니다. 미국이나 영어권 국가에서는 숫자를 표기할 때, 3자리마다 숫자를 끊어 콤마를 삽입하여 사용합니다.

 

 

 * 만약 지역 값을 입력하지 않고 호출하는 경우, 해당 시스템의 지역 값에 따라서 숫자가 표기되는데, 시스템에 따라서 뒤에 소수점 2자리가 붙는 경우가 있습니다.

 - Number("12345").toLocaleString('en'); ===> 12,345.00

 

 이럴 때에는 단순히 소수점을 날려버리는 코드만 추가해 주시면 됩니다. (방법1에서도 가장 마지막 라인에서 사용한 방법입니다.)

 - Number(data_value).toLocaleString('en').split(".")[0] ===> 12,345

 

 숫자가 아닌, Date 타입도 toLocaleString 함수를 제공하는데, 이 때에는 함수 인자값에 해당하는 지역의 Date 표기 형식의 값을 반환해줍니다.



출처: http://ooz.co.kr/231 [이러쿵저러쿵]

출처: http://ooz.co.kr/231 [이러쿵저러쿵]

출처: http://ooz.co.kr/231 [이러쿵저러쿵]

+ Recent posts