This project has two purposes:
- Being a playable game human vs. machine
- Being a demonstration of the Model-View-ViewModel design pattern with a hopefully meaningful use purpose
In a Model-View-ViewModel (abbreviated MVVM) - project, code is strictly separated into different sections:
- The Model section, responsible for the logic (not necessarily the so-called business logic)
- The View section, enabling interaction with the user
- The ViewModel section, linking between both by sending and receiving messages
Model and View do not know each other; they communicate indirectly with the aid of the ViewModel.
Compared to other design patterns, Model is a little less than a backend (because it must not make its own decisions but has to wait until invoked), and View is a little more than a display section (because it may contain its own logic which has to be related to user interaction tasks).
In this realisation, ViewModel represents a guard over the game's rules, deciding which player may continue, which moves are allowed etc.
Using MVVM is always a little more complex than executing subsequent code directly, and the application usually performs a little slower. It requires a higher abstraction level when designing the project.
On the other hand, it enables to treat different sections separately what might be useful when maintaining or extending the application. To demonstrate this possible advantage, I created three different versions, sharing parts of the other ones:
Javascript Browser Version and Console Version share (almost) the same Model, having different Views.
PHP Browser Version and Javascript Browser Version share exactly the same View, having different Models.
All versions have at least more or less the same ViewModel in common.
- Download project and execute file index.html in a browser of your choice
OR
- Click above link