Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
4f75ef8
feat: setup baseball game project
wmakerjun Nov 24, 2020
6699134
docs: 요구사항 목록 작성
gxxrxn May 19, 2022
e5bbfd2
chore: prettier, eslint 설정
gxxrxn May 22, 2022
3e8078a
feat: BaseballGame computerInputNumber 생성 기능 구현
gxxrxn May 22, 2022
8ea0a98
chore: 불필요한 html 텍스트 제거
gxxrxn May 22, 2022
1bbc30e
docs: 기능 구현에 따른 요구사항 목록 업데이트
gxxrxn May 22, 2022
7db0f00
fix: BaseballGame computerInputNumber 생성 기능 수정
gxxrxn May 22, 2022
f20b092
feat: BaseballGame 정답 비교 기능 구현
gxxrxn May 22, 2022
85c9959
docs: 기능 구현에 따른 요구사항 목록 업데이트 및 수정
gxxrxn May 22, 2022
3f2a562
feat: BaseballGame에서 결과를 화면에 띄우는 render함수 구현
gxxrxn May 22, 2022
144843a
docs: 기능 구현에 따른 요구사항 목록 업데이트
gxxrxn May 22, 2022
77e984c
feat: 정답을 맞추면 게임 종료 및 재시작 기능 구현
gxxrxn May 22, 2022
fc656a9
docs: 기능 구현에 따른 요구사항 목록 업데이트
gxxrxn May 22, 2022
d3ae8a9
feat: BaseballGame user input 유효성 검사 기능 구현
gxxrxn May 22, 2022
8981f4e
docs: 기능 구현에 따른 요구사항 목록 업데이트
gxxrxn May 22, 2022
7bae84e
Merge branch 'upstream/main' into greantea
gxxrxn May 22, 2022
998e089
chore(eslint): eslint 에러 해결
MINJOO-KIM May 25, 2022
453dbad
refactor(validator): isNaN 함수 생성 후 validator로 분리
MINJOO-KIM May 25, 2022
fd45671
refactor(event): submit 이벤트 핸들러 함수로 분리
MINJOO-KIM May 25, 2022
299d983
refactor(BaseballGame): BaseballGame에서 분리가능한 함수 분리
MINJOO-KIM May 29, 2022
219f8d8
refactor(selector): dom 저장 변수 이름 수정
MINJOO-KIM May 29, 2022
8a5be44
refactor(selector): DOM_ID 상수로 분리
MINJOO-KIM May 29, 2022
749a364
refactor(BaseballGame): resultView에 click 이벤트 추가
MINJOO-KIM May 29, 2022
58cc765
refactor(constants): STRING에 빈문자열, 개행 선언
MINJOO-KIM May 29, 2022
43f4ee8
refactor(BaseballGame): strike, ball 관련 변수명 변경
MINJOO-KIM May 29, 2022
c51edf2
refactor(BaseballGame): render 함수 매개변수명 변경
MINJOO-KIM May 29, 2022
86f3055
refactor(validator): 사용하지 않는 함수 export 제외
MINJOO-KIM May 29, 2022
30489fb
refactor(BaseballGame): 볼, 스트라이크 카운팅 로직 util로 분리
MINJOO-KIM May 30, 2022
5cfb200
refactor(validation): 유효성 검사 디렉토리 위치 변경
MINJOO-KIM May 30, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions .eslintrc.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
env:
browser: true
es6: true
node: true
extends:
- airbnb
12 changes: 12 additions & 0 deletions .prettierrc.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
arrowParens: 'always'
bracketSpacing: true
jsxBracketSameLine: false
jsxSingleQuote: false
printWidth: 80
proseWrap: 'always'
quoteProps: 'as-needed'
semi: true
singleQuote: true
tabWidth: 2
trailingComma: 'es5'
useTabs: false
25 changes: 25 additions & 0 deletions docs/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<p align="middle" >
<img width="200px;" src="https://github.com/woowacourse/javascript-baseball-precourse/blob/main/images/baseball_icon.png?raw=true"/>
</p>
<h1 align="middle">숫자 야구 게임</h1>

## 게임 설명

1부터 9까지 서로 다른 수로 이루어진 3자리의 수를 맞추는 게임이다.

## 기능 요구사항

- [x] 1 ~ 9까지 서로 다른 임의의 수 3개를 랜덤으로 선택하여 정답으로 설정한다.
- [x] 3자리의 수를 입력받는다.
- 입력받은 수와 정답을 비교해서 힌트를 띄운다.
- [x] 숫자가 같은 위치에 있는 경우 `스트라이크` 힌트를 전달한다.
- [x] 숫자가 다른 위치에 있는 경우 `볼` 힌트를 전달한다.
- [x] 숫자가 존재하지 않는 경우 `낫싱` 힌트를 전달한다.
- [x] 힌트는 볼, 스트라이크 순서로 전달한다.
- [x] 힌트를 출력한다.
- [x] 입력받은 수와 정답이 같으면 게임이 종료되고, 게임을 재시작할 수 있다.
- [x] 잘못된 값을 입력한 경우, 에러 메시지가 뜨고 값을 재입력할 수 있다.
- [x] 수를 중복해서 입력한 경우
- [x] 입력한 수가 3자리가 아닌 경우
- [x] 숫자가 아닌 문자 등을 입력한 경우
- [x] 공백이 입력된 경우
49 changes: 23 additions & 26 deletions index.html
Original file line number Diff line number Diff line change
@@ -1,30 +1,27 @@
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8" />
<title>숫자 야구 게임</title>
</head>

<head>
<meta charset="UTF-8" />
<title>숫자 야구 게임</title>
</head>

<body>
<div id="app">
<h1>⚾ 숫자 야구 게임</h1>
<p>
<strong>1~9까지의 수</strong>를 중복없이
<strong>3개</strong> 입력해주세요. <br />
올바른 예) 139 <br />
틀린 예) 122
</p>
<form>
<input type="text" id="user-input" />
<button id="submit">확인</button>
</form>
<h3>📄 결과</h3>
<div id="result">1볼 1스트라이크</div>
<button id="game-restart-button">재시작</button>
</div>
<script src="https://cdn.jsdelivr.net/npm/@woowacourse/[email protected]/dist/mission-utils.min.js"></script>
<script type="module" src="src/index.js"></script>
</body>

<body>
<div id="app">
<h1>⚾ 숫자 야구 게임</h1>
<p>
<strong>1~9까지의 수</strong>를 중복없이
<strong>3개</strong> 입력해주세요. <br />
올바른 예) 139 <br />
틀린 예) 122
</p>
<form>
<input type="text" id="user-input" />
<button id="submit">확인</button>
</form>
<h3>📄 결과</h3>
<div id="result"></div>
</div>
<script src="https://cdn.jsdelivr.net/npm/@woowacourse/[email protected]/dist/mission-utils.min.js"></script>
<script type="module" src="src/index.js"></script>
</body>
</html>
Loading