I really like the way EJS templates work, because the meta-language (loops, if-then-else, etc.) is just JavaScript. This blog post describes ideas for improving their syntax.
As of version 6, Babel supports presets, sets of features that can be enabled together. This blog post looks at three new useful Babel presets (and, as a bonus, two presets especially for Node.js).
This blog post describes a new setup for presenting with Apple’s Keynote app that I’ve experimented with. It involves:
The ECMAScript proposal “Template Literal Revision” by Tim Disney reached stage 4 and will be part of ECMAScript 2018. It proposes to give the innards of tagged template literals more syntactic freedom.
Function.prototype.toString
revisionThe ECMAScript proposal “Function.prototype.toString
revision” (by Michael Ficarra) is at stage 4 and therefore part of ECMAScript 2019. It brings two major improvements compared to ES2016:
toString()
must return that source code. In ES2016, whether to do so is left up to engines.toString()
could not (or would not) create syntactically valid ECMAScript code, it had to return a string for which eval()
throws a SyntaxError
. In other words, eval()
must not be able to parse the string. This requirement was forward-incompatible – whatever string you come up with, you can never be completely sure that a future version of ECMAScript doesn’t make it syntactically valid. In contrast, the proposal standardizes a placeholder: a function whose body is { [native code] }
. Details are explained in the next section.For health reasons, I’m taking June–August off from work (Twitter, blogging, etc.). See you in September!
In this blog post, I show six tricks enabled by new ES6 features. At the end of each section, I point to related material in my book “Exploring ES6” (which is free to read online).
In this blog post, we look at problems that arise when template literals contain whitespace:
This blog post shows how to handle trees of ES6 Promises, via an example where the contents of a directory are listed asynchronously.
In Promise-based asynchronous code, rejections are used for error handling. One risk is that rejections may get lost, leading to silent failures. For example:
function main() {
asyncFunc()
.then(···)
.then(() => console.log('Done!'));
}
If asyncFunc()
rejects the Promise it returns then that rejection will never be handled anywhere.
Let’s look at how you can track unhandled rejections in browsers and in Node.js.