메뉴 건너뛰기

2020.11.23 16:38

6장 오픈챌린지 질문

조회 수 276 댓글 1

 

 

prompt로부터 받은 값은 문자열이잖아요..?

그런데 왜 get을 parseInt로 정수화해주지 않았는데도 정상실행이 되는건지 잘 모르겠어요.

 

-------------------------------------------------------------------------

<!DOCTYPE html>

<html>

    <head></head>

    <body>

        <h2>별 문자 출력하기</h2>

        <hr>

        <script>

            get=prompt("정수를 입력하세요","");

            if(isNaN(get)){

                document.write("입력 오류 입니다.");

            }

            else{

                for(var i=0; i<get; i++){

                    for(var j=0; j<=i; j++){

                        document.write("*");

                    }

                    document.write("<br>");

                }                

            }

        </script>

    </body>

</html>

?
  • ?
    관리자 2020.11.24 09:00
    parseInt에 대해 알 고 있는 분이군요. 좋은 질문입니다.
    1. 그런데 만일 다음 코드 후
    get=prompt("정수를 입력하세요","");

    사용자가 "hello"라고 입력하였다고 합시다.
    parseInt(get) 하면 여기서 오류가 나서 프로그램 실행이 종료하게 되지요.

    그래서 오히려 다음 조건문을 사용합니다.
    if(isNaN(get)){

    즉 get에 들어 있는 내용이 숫자인지 숫자가 아닌 문자열인지를 판단합니다.
    만일 숫자가 아닌 문자열인 경우 다음의 오류 메시지를 출력하고
    document.write("입력 오류 입니다.");

    for 반복문이 실행되지 않게 합니다.

    2. 또 이런 의문을 품을 수 있겠군요.
    그러면 다음 for 문안에서 get은 문자열인데 정수 값을 가진 변수 i와 get이 어떻게 비교될 수 있나요?
    for(var i=0; i<get; i++){

    이것도 좋은 의문입니다.
    이 코드가 실행되는 시점에서 get은 분명히 숫자의 문자열 입니다("5"와 같이).
    자바스크립트는 타입의 경계를 엄격하게 체킹하지 않고(loosely typed) 숫자를 가진 문자열의 경우 숫자와 같이 다룹니다.
    정말 정확히 코드를 작성하려면 다음과 같이 하면 됩니다.
    k = parseInt(get)
    for(var i=0; i<k; i++){

    for(var j=0; j<=i; j++){

    document.write("*");

    }

    document.write("<br>");

    }

QnA

공부하면서 궁금했던 것을 질문해보세요.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18304
243 9장 예제 9-10질문입니다. 2 file 삼오칠 2021.05.14 365
242 9장 오픈챌린지 답이 너무 궁금합니다. 1 범이 2017.05.10 1253
241 ; 가 쓰일 때를 여쭙고 싶습니다 2 file 입문한 사람 2020.04.07 141
240 ; 에 대해 질문드립니다 1 입문한 사람 2020.04.01 85
239 a<<b가 뭔가요? 1 2020.07.01 103
238 Atom은 IDE 리스트에서 삭제해주세요. 1 삼오칠 2023.04.15 84
237 border style 질문 2 궁그미 2020.07.28 41
236 ch1 이론문제 1번 2 새내기 2021.03.06 221
235 chapter5 오픈챌린지 5장 아예 모르겠어요.. 열심히해보자 2020.11.03 312
234 css3로 웹 페이지 꾸미기 3 file ㅇㅇ 2020.04.30 109
233 css3의 프로퍼티와 7장 객체의 프로퍼티 1 한성이 2022.08.07 38
232 div 와 pre 중에서 어떤 게 더 상위에 위치하나요? 1 file 입문한사람 2020.04.03 751
231 document.getElementBy~ 2 tc0712 2021.11.22 108
230 document.write 내부에서의 onclick 이벤트 선언에 대한 오류 1 tlqk 2019.11.24 445
229 DOM트리 질문 1 열심히 공부하는 독자 2020.08.17 76
228 form 태그 1 열공이 2023.01.31 88
227 form 태그와 웹서버 1 tc0712 2021.09.29 103
226 html5 태그 검사 2 열공이 2022.03.10 94
225 HTML5+CSS3+Javascript 웹 프로그래밍[수정판] 4 file Jenny 2021.09.25 519
224 html에 css작성할때 2 궁금이 2020.03.03 353
목록
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 ... 21 Next
/ 21
위로