Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mell62/battleship
The classic game of battleship, computer-coded into digital reality
https://github.com/mell62/battleship
babel css dom-manipulation eslint esmodules flexbox grid html jest test-driven-development webpack
Last synced: 3 days ago
JSON representation
The classic game of battleship, computer-coded into digital reality
- Host: GitHub
- URL: https://github.com/mell62/battleship
- Owner: mell62
- Created: 2024-10-27T14:24:07.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-11-29T18:58:03.000Z (3 months ago)
- Last Synced: 2024-12-28T10:36:10.027Z (about 2 months ago)
- Topics: babel, css, dom-manipulation, eslint, esmodules, flexbox, grid, html, jest, test-driven-development, webpack
- Language: JavaScript
- Homepage: https://mell62.github.io/battleship/
- Size: 262 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Battleship
The classic game of battleship, implemented using HTML, CSS, JavaScript, webpack and Jest testing framework, showcasing the power of test-driven development.
Check it out :point_right:[here!](https://mell62.github.io/battleship/):point_left:
data:image/s3,"s3://crabby-images/55c2c/55c2c1f45816e3445f0279a2f84af24048daa6f7" alt="webpage-screenshot"
## :joystick: Features
- Select desired ship and hover and click over friendly board to place it; option to rotate ship is available by clicking on direction button
- Ships cannot be placed adjacent to each other
- Turn-based attack mechanism: When the player makes an attack, the game enters a waiting period until computer finishes its attack.## :tada: Achievements
- **Webpack** is utilized for the bundling of code of multiple files through ES6 Modules and minification
- **Jest** testing framework is used for unit testing game logic, ensuring integrity and bug-resistant code
- **Test-driven-development** principles practised through Jest, ensuring high-quality code## :grey_exclamation: Limitations
- Tests not implemented for UI integration
- Player vs player not implemented## :magic_wand: Extras!
- Realistic intelligence implemented for computer attacks
- Appropriate icons and game messages is displayed for each type of attack## :page_with_curl: Note
- Modern normalize is used for cross-browser consistency
- ESLint is used for code analysis
- Babel is used to transpile code for compatibility with older browsers