Skip to content

AnnAnnaU/js_2048_game

 
 

Repository files navigation

  1. Replace <your_account> with your Github username in the link
  2. Follow this instructions
    • There are no tests for this task so use npm run lint command instead of npm test

Task: 2048 game

Hey! Are you ready for a real hard check of your JavaScript skills, ninja? If you are still here, let's do it.

In this task, you need to implement the 2048 game like in this reference Don't play for so long! We need back to work.

Okay, what we have?

  1. HTML and CSS are completely done. So you can use it, or implement your own design if you want.
  2. Reference.

That's all.

Okay, okay. Also, we have some rules:

  1. The game field is 4 x 4
  2. Each cell can be empty or contain one of number: 2, 4, 8 ... 2^n
  3. The player can move cells with keyboard arrows
  4. All the numbers should be moved in the selected direction as much as possible
    • 2 equal cells should be merged into a doubled number
    • The merged cell can’t be merged twice during one move
  5. The move is possible if something will be changed after that
  6. After move 2 or 4 appears in a random empty cell. 4 probability is 10%
  7. When 2048 collected should be shown win message.
  8. The game over message should be shown if there are no more available moves.
  9. Hide start message after begin.
  10. Change the Start button to Restart after begin.
  11. Increase score with each move. The score should be increased by the sum of all merged cells.

Hints:

  • You have class field-cell--%cell_value%, for styling cell in the game.
  • Use hidden class for hiding elements on page.
  • Use start, restart classes for the main button for different styles.
  • Use field-cell--%cell_value% class like additional class, don't replace the main class.

You can change the HTM/CSS layout if you need it.

Preview

About

JS Advanced task. Create a 2048 game.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • SCSS 53.2%
  • HTML 38.1%
  • JavaScript 8.7%