https://www.youtube.com/channel/UCEGUP3TJJfMsEM_1y8iviSQ
The main topic around the conference was, to no one's surprise, AngularJS v2.0
When will it be released? What will it bring? What will it break?
The answers to which break down to: Soon ™; The same but faster and using future standards; And a lot less than some people are panicking about.
If I were to sum up what I've seen of AngularJS v2.0: It will have everything that AngularDart got, with some of the crust cut off.
In fact, the Angular team have organised the source code so that they can build AngularJS and AngularDart from the same code base, which is an impressive feat.
New Syntax
Wait... but how can they do that?AngularDart uses classes and type reflection to handle dependency injection, and annotations for marking classes as directives or web components.
These things aren't in Javascript...
But they are in ES6, TypeScript, and AtScript.
Confused?
That's where this slide comes in handy.
Classes
The class syntax is being standardised in ES6.
And when it's compiled down to ES5, it uses the good old Javascript prototype chain: Effective but ugly.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ES6 Class | |
class MyClass { | |
constructor() { | |
this.a = "b"; | |
} | |
getA() { | |
return this.a; | |
} | |
} | |
// ES5 Equivalent | |
function MyClass() { | |
this.a = "b"; | |
} | |
MyClass.prototype.getA = function() { | |
return this.a; | |
}; |
Types
For Angular v2.0, the Angular team wants to move away from this idea that everything must be registered explicitly with Angular (ie. module.factory(), module.value(), etc.) and instead just use classes. Same way it's been done for AngularDart.
The trouble is that ES6 still has no syntax for declaring that a parameter should be a particular type.
If I want my function to only accept parameter "meep" if it came from "MyClass", then I'm going to have to do my own manual "meep instanceof MyClass" check.
This is where the "name:type" syntax comes in. It provides both type assertions at runtime, and documentation.
It's currently being used by TypeScript, and a proposal was drafted for ES6, but it looks like it will be deferred till ES7 at least.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// TypeScript types | |
function myFn(name:string, obj:MyClass) { | |
// ... | |
} | |
// Equivalent ES5 | |
/** | |
* @param name {string} | |
* @param obj {MyClass} | |
*/ | |
function myFn(name, obj) { | |
assert(typeof name === 'string'); | |
assert(obj instanceof MyClass); | |
// ... | |
} |
Type Introspection
What TypeScript does is great for doing type checking on values, but it doesn't actually help with things like dependency injection. It's not about passing in the correct values to a function - It's about knowing what the function wants in the first place.
That's where the need for type introspection (or type reflection) comes in.
Looking at the code generated by traceur, AtScript's solution is to attach the classes or some equivalent to the function as a property called "parameters". Simple, but effective.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// AtScript types | |
function myFn(name:string, obj:MyClass) { | |
// ... | |
} | |
// Equivalent ES5 | |
/** | |
* @param name {string} | |
* @param obj {MyClass} | |
*/ | |
function myFn(name, obj) { | |
assert(typeof name === 'string'); | |
assert(obj instanceof MyClass); | |
// ... | |
} | |
myFn.parameters = [[String], [MyClass]]; |
Annotations
The last piece is annotations. Metadata which declares something about a class or function without directly interfering with it.
Annotations become a property of the function called "annotations", similar to parameters.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// Annotation in AtScript | |
@MyAnnotation({a: 'b'}) | |
function fn() {} | |
// Equivalent ES5 | |
function fn() {} | |
fn.annotations = [new MyAnnotation({a: 'b'})]; |
Final Thoughts
All of these new syntaxes are going to be added to Javascript, sooner or later, and I believe they'll be a welcome addition to the language.
Creating class-like structures right now requires either a third-party library or some very ugly looking uses of the 'prototype' property. It's about time it got standardised.
Fact: Types are useful.
If you don't want to use them, fine. The type system is optional.
If you don't want to use them, fine. The type system is optional.
But they can help stop trivial bugs, make IDEs more useful, and refactoring a lot easier.
And I think the way Angular uses annotations proves just how useful they can be.
Next Time
Next time I'm going to take a look through the things Igor and Tobias mentioned will be killed off in Angular v2.0, and what will replace them.
After that I'll take a look at a few things we could do in v1.x that might make migrating to v2.0 a little less jarring.
After that I'll take a look at a few things we could do in v1.x that might make migrating to v2.0 a little less jarring.
Till then.
Cheers,
Jason Stone
No comments:
Post a Comment