JavaScript
JavaScript (often abbreviated to JS) is a scripting language used by most web browsers. Roguelikes can also use it as a scripting language (e.g. for scripted events or quests). This allows changing game behavior without recompiling. Some browser-based roguelikes are written in JavaScript or its Microsoft relative JScript (and JScript.NET). With the advent of Node.js, io.js and v8, JavaScript can be used outside of the browser as well.
Development Hints
- Use jsLint to avoid many mistakes that are normally caught by a compiler
- JavaScript frameworks abstract many of the browser inconsistencies. (MooTools, JQuery)
- Take advantage of Firebug for Firefox, the Web Inspector for Chrome and Safari and the Developer Tools in Internet Explorer (version 8 and above)
- Full IDEs are available including Microsoft Visual Studio Web Developer Express, Aptana and NetBeans.
- Rot.js is a JavaScript roguelike library with many useful features.
Advantages
- Scripting languages usually have a faster feedback loop between development and viewing the changes.
- Closures are a powerful language construct that can simplify application structure and enhance readability.
- Any user with a modern browser (on any platform) can run your game.
- A whole new world of easy-to-access graphical possibilities with the DOM or
- Working in a dynamic and garbage collected language takes a lot of the pain out of strong typing and memory management.
- Well supported serialization of data structures using JSON.
- Emerging HTML5 standards provide support for local storage of data.
- Emerging web application stores, such as the Google Chrome Store, provide a distribution platform.
Disadvantages
- Many errors that are caught at compile-time in a strongly typed language will be caught at run-time.
- Existing source for most roguelikes is in C or C++, and not all idioms translate into JavaScript.
- There are browser differences in JavaScript implementations and javascript speed, so true portability still takes work.
- JavaScript is much slower than C and C++ (however, not all roguelikes require blazing speed).
- Full file system access requires additional plugins.
- JavaScript, owing to its troubled past, has more than the average share of design flaws and overall quirkiness.
HTML and CSS
The collection of web standards that is sometimes loosely referred to as HTML offers a multitude of methods to interface with the user.
HTML, CSS and the DOM (Document Object Model)
This approach is also informally known as DHTML, for dynamic HTML. It involves using the functionality of HTML elements and their styling together with JavaScript to create a dynamically-changing web page. Traditional DHTML is only of utility to very simple games, since it is not possible to escape the limits of HTML markup, which was not designed to make program interfaces, but static documents.
Canvas 2D context
Canvas 2D that emerged in 2004 from Apple, and is currently supported by all popular modern web browsers (with Internet Explorer being an exception up to version 9). Canvas 2D in itself is a rather simple 2D API with a set of basic functions for drawing lines, arcs, curves and polygons. The API is packaged in the form of the
Canvas WebGL context
The WebGL context of the
SVG and its DOM
Animating SVG with JavaScript via its DOM is the rarest method of building an interface with the user. Although SVG was designed to create graphical presentations, the complexity of using its DOM makes it similar to DHTML in many respects.
Roguelikes in JavaScript
JavaScript Roguelike Libraries