Silly story generator
이 모듈에서 배운 지식들을 바탕으로 랜덤하게 꾸며진 이야기(silly stories)가 만들어지는 재미있는 앱을 만들어 볼거에요. 즐겨봅시다!
필요한 사전 지식: | 이 평가에 시도하기 전에 이 모듈에서 배운 항목을 모두 수행해봐야 합니다. |
---|---|
목표: | 변수, 숫자, 연산자, 문자열 및 배열 같은 JavaScript의 기본 항목에 대한 전반적인 이해를 테스트합니다. |
시작하기
이 평가를 시작하기 전에, 아래와 같은 것을 해야 합니다.
- HTML 예제 파일이 있는 사이트로 이동하여 파일을 복사하여 자기 컴퓨터에 새 디렉토리를 만들고 파일이름
index.html
로 저장합니다. 이 안에는 예제를 위한 CSS가 포함되어 있습니다. - 또 다른 가공 전의 텍스트가 있는 사이트 로 가서 별도의 브라우저 탭으로 열어 놓으세요. 이것은 나중에 필요합니다.
위 방법 대신에, 여러분은 테스트에 JSBin 또는 Glitch 같은 사이트를 이용할 수 있습니다. 이 온라인 에디터들 내부에 HTML, CSS 그리고 JavaScript를 붙여넣을 수 있습니다. 만약 당신이 사용하는 온라인 에디터가 Javascript 패널(또는 탭)을 갖고 있지 않다면, 자유롭게 HTML 페이지 내부에 <script>
엘리멘트를 넣을 수 있습니다.
참고: 문제가 해결되지 않으면 이 페이지 하단의 평가 또는 추가 도움말 섹션을 참조해 도움을 요청하세요.
프로젝트에 대한 간략한 설명
이제 프로젝트 시작을 위해 가공하지 않은 HTML/CSS 그리고 몇몇 텍스트를 만들고 확인했습니다. 이제 아래와 같은 기능을 하는 프로그램을 만들기 위해 JavaScript를 코딩해야 합니다.
- "Generate random story" 버튼를 누를 때 마다 꾸며진 이야기를 만들어야 합니다.
- 생성 버튼을 누르기 전에 "사용자 지정 이름 입력" 텍스트 필드에 사용자 지정 이름을 입력한 경우에만 스토리의 기본 이름인 "Bob"을 사용자 지정 이름으로 바꿉니다.
- 생성 버튼을 누르기 전에 영국 라디오 버튼을 선택한 경우 스토리의 기본 미국 무게 및 온도 수량과 단위를 영국 단위로 변환합니다.
- 버튼을 누를 때마다 새로운 꾸며진 스토리를 무작위로 생성합니다.
다음 스크린샷은 완성된 프로그램이 출력해야 하는 내용의 예를 보여줍니다.
더 많은 아이디어를 얻으려면 완성된 예제를 살펴보세요. 하지만 소스 코드를 들여다보지 마세요!
완료하기
이번 섹션에선 프로젝트를 어떻게 진행해야 하는지 자세하게 설명합니다.
기본 설정:
index.html
파일과 같은 디렉토리에main.js
라는 이름의 파일을 새로 만듭니다.main.js
를 참조하는 HTML에<script>
요소를 삽입하여 외부 JavaScript 파일을 HTML에 적용합니다. 닫는</body>
태그 바로 앞에 넣습니다.
초기 변수와 함수:
- 가공 전의 텍스트 파일에서, "1. COMPLETE VARIABLE AND FUNCTION DEFINITIONS" 바로 밑의 코드를 모두 복사해서
main.js
파일의 맨 위에 붙여넣습니다. 이 내용은 세 개의 변수 제공하는데,customName
변수는 "Enter custom name" 텍스트 필드 값을 저장하고,randomize
변수에는 "Generate random story" 버튼 객체를 저장하고, HTML 바디에 끝에 있는 클래스가story
인<p>
요소는 story 변수에 저장하며 해당 요소에는 랜덤한 이야기가 복사됩니다. 또한,randomValueFromArray()
함수는 배열을 가져와서 배열이 가진 항목 중 하나를 랜덤하게 반환합니다. - 가공전 텍스트 파일의 두번째 섹션 "2. RAW TEXT STRINGS"에는 프로그램에 자동으로 입력되어 랜덤 이야기 요소에 출력하는 문자열이 포함되어 있습니다.
main.js
에 아래 설명대로 변수를 만듭니다:- 먼저
storyText
변수에 굉장히 긴 가장 첫 번째 문자열을 저장합니다. insertX
배열에 세 개의 문자열 집단의 첫 번째를 저장합니다.insertY
배열에 세 개의 문자열 집단의 두 번째을 저장합니다.insertZ
배열에 세 개의 문자열 집단의 세 번째를 저장합니다.
- 먼저
이벤트 핸들러와 완성되지 않은 함수 배치:
- 가공되지 않은 텍스트 파일로 돌아갑니다.
- "3. EVENT LISTENER AND PARTIAL FUNCTION DEFINITION" 밑의 코드를 복사하고,
main.js
파일의 맨 밑에다 붙여 넣으세요.randomize
변수에 클릭 이벤트 리스너를 추가하세요. 그러면 버튼이 클릭되었을 때,result()
함수가 실행됩니다.- 코드에 부분적으로 완료된
result()
함수를 추가하세요. 이 평가의 뒤 부분에서 함수가 완성되고 정상적으로 동작하도록 내용을 추가할 것입니다.
result()
함수 완성하기:
newStory
라 불리는 새 변수를 만들고, 이것의 값을storyText
와 똑같이 설정하세요. 이것은 버튼을 누르고 함수가 수행될 때 마다 새 이야기('story')가 임의로 만들어 질 수 있게 합니다.storyText
를 직접 변경했다면, 새로운 이야기를 한번만 만들 수 있습니다.- 세 개의 새로운 변수
xItem
,yItem
, 와zItem
를 만들고 이 세 개의 변수를randomValueFromArray()
의 반환 결과인 세 개의 배열과 같도록 만듭니다(각 경우의 호출 결과는 각 배열에 임의의 아이템이 됩니다.) 예를 들어randomValueFromArray(insertX)
에 의해 작성된insertX
에서 하나의 문자열을 임의로 반환하는 함수를 얻고, 호출할 수 있습니다. - 그 다음으로
newStory
문자열에 있는 세 개의 placeholders—:insertx:
,:inserty:
,:insertz:
—저장된xItem
,yItem
와zItem
문자열을 이용하여 변환하세요. 여기서 특정 문자열 함수가 도움될 것입니다. 이 함수는 각 경우에newStory
와 같게 되며, 호출 시 마다newStory
의 원래 값과 동일하지만 대체 될 수 있습니다. 그러므로 버튼이 눌러질때마다, 이 placeholder는 지정된 문자열로 랜덤하게 교체되게 됩니다. 추가적인 힌트로, 이 문제의 함수는 하위 문자열에서 찾은 첫번째 인스턴스만 변경하므로, 아마도 두번 이상 이 함수를 호출해야 할 수도 있습니다. - 첫번째
if
블록에서,newStory
의 'Bob'이라는 이름을name
변수를 사용하여 변환하는 함수를 추가하세요. 이 블록에서 말하는 내용은 "만약customName
텍스트 입력에 값이 들어가 있다면, 이야기속의 Bob을 사용자가 정의한 이름으로 바꾸세요" 라는 의미입니다. - 두번째
if
블록에서는uk
라디오 버튼이 선택되었는지 확인합시다.uk
라디오 버튼이 눌려졌다면, 이야기 상의 무게와 온도 값들인 파운드와 화씨온도를 스톤과 섭씨온도로 바꾸어야 합니다. 필요한 것은 아래와 같습니다.- 파운드를 스톤, 화씨온도를 섭씨온도로 변환하는 공식을 참조해 보세요.
weight
변수를 정의하는 라인에서는, 300 파운드를 스톤으로 변환합니다. 변환 결과값을Math.round()
를 실행한 결과값 끝에stone
을 결합합니다.temperature
변수를 정의하는 줄에서는, 94를 화씨에서 섭씨온도로 변환합니다. 변환 결과값을Math.round()
를 실행한 결과값 끝에' centigrade'
을 결합합니다.- 두 변수 정의 바로 밑에, '94 화씨온도로
temperature
변수의 내용을 변환하는 것과, '300 pounds'을weight
변수의 내용을 바꾸는 두줄의 문자열 변환라인을 추가합니다.
- 마지막으로 함수의 두 번째 줄에서 마지막 줄에 단락을 참조하는
story
변수의textContent
속성을newStory
와 동일하게 설정합니다.
힌트와 팁
- JavaScript 내용 외에는 HTML을 수정할 필요가 없습니다.
- 만약 JavaScript가 정상적으로 HTML에 적용되었는지 의심스럽다면, 일시적으로 JavaScript의 내용을 지우고, 단순하고 짧은 효과가 명확한 내용을 추가해서, 저장하고 새로고침을 해보세요. 예를 들어 다음은
<html>
요소의 배경을 빨간색으로 바꾸므로 JavaScript가 제대로 적용되었다면 브라우저 창 전체가 빨간색으로 바뀌어야 합니다.jsdocument.querySelector("html").style.backgroundColor = "red";
- Math.round() 는 가장 가까운 정수로 단순하게 반올림한 결과를 반환하는 JavaScript 내장함수 입니다.
- 바꾸어야 하는 문자열에는 세 가지 인스턴스가 있습니다.
replace()
메서드를 여러 번 반복하거나replaceAll()
을 사용할 수 있습니다. 문자열은 불변이라는 점을 기억하세요!
평가 또는 추가 도움말
작업 평가를 받고 싶거나 막혀서 도움을 요청하고 싶은 경우.
- 온라인 공유가 가능한 CodePen, jsFiddle, 또는 Glitch 같은 에디터에 작업한 것을 올려 두세요.
- 평가 또는 도움을 요청을 MDN Discourse forum Learning category 에 게시글을 쓰세요. 게시글에는 다음이 포함되어야 합니다.
- "Assessment wanted for Silly story generator"와 같은 서술적인 제목이 필요합니다.
- 이미 시도한 작업의 세부 사항과 트위터에 바라는 사항을 알려주세요. 예를 들어 문제가 발생하여 도움이 필요하거나 평가를 원하는 경우가 있습니다.
- 평가 받거나 도움이 필요한 예제에 대한 온라인 공유 가능 편집기 링크(위 1단계에서 설명한 대로)가 필요합니다. 코드를 볼 수 없다면 코딩 문제가 있는 사람을 도와주기가 매우 어렵기 때문에 이 방법을 사용하는 것이 좋습니다.
- 실제 과제 또는 평가 페이지로 연결되는 링크로, 도움을 받고자 하는 문제를 찾을 수 있습니다.