Frontend Development
@
Picnic Software
@basarat
data:image/s3,"s3://crabby-images/47847/47847166c8d39ec9c198f00676c6100e9cb7828b" alt=""
data:image/s3,"s3://crabby-images/c8480/c8480846b741d941b64a28bf36c1ae0cedad24da" alt=""
TypeScript
Types + JavaScript of the future
data:image/s3,"s3://crabby-images/d10b7/d10b7e76149d159cde525417b0bdaea56e16a6e5" alt=""
TypeScript
Classes and Lambdas
data:image/s3,"s3://crabby-images/9d85e/9d85e9e2f9e7d8ed22e801f9cd075964c8720031" alt=""
Source http://goo.gl/McnWTJ
Video http://goo.gl/HNnn0i
TypeScript
Discoverability
data:image/s3,"s3://crabby-images/bf526/bf5263693b79edd182b8035ec06545dbde544f3f" alt=""
TypeScript
Refactoring
data:image/s3,"s3://crabby-images/c2309/c2309c896e2cda3286b52b8705d506aeb95ec6de" alt=""
TypeScript
Generated DTO
data:image/s3,"s3://crabby-images/57e7e/57e7e2ca115fb7017c5d62a09d780767122cb8b4" alt=""
Generated Services
data:image/s3,"s3://crabby-images/09994/099943ef1e9b50df0a6cc12a82ac4350a5840e72" alt=""
TypeScript
TypeSafety is good
data:image/s3,"s3://crabby-images/b480b/b480b393dac0139af82f09354254c2ee5eac1644" alt=""
Not an all or nothing proposition
All our code is in TypeScript. But you can start using it quite quickly.
- Your JavaScript is TypeScript.
- When it isn't you can type it.
- Most of the popular open source projects have a TypeScript definition (DefinitelyTyped)
RequireJS
Let the files manage their own ordering
data:image/s3,"s3://crabby-images/39bc5/39bc5a203a5e6c15134e556daf0d7a7554f05d15" alt=""
Fast incremental compile https://github.com/TypeStrong/grunt-ts#fast-compile
Angular JS
Full stack. More than just a databinding framework (Routing, Directives)
data:image/s3,"s3://crabby-images/5aa6a/5aa6a9bc0dab33f1b109fd5fe4777a021fbbc173" alt=""
AngularJS
I'm sure you've seen the google trend (http://goo.gl/psnLgv)
data:image/s3,"s3://crabby-images/a849f/a849f5438b557e2127db28564eb287dc2a56ba1c" alt=""
Other Frameworks
data:image/s3,"s3://crabby-images/03e4c/03e4cb2435a8e4ece713f36425e69b06a06950f9" alt=""
With TypeScript
Does not impose any restrictions on your code.
Just works with JavaScript.
With TypeScript
data:image/s3,"s3://crabby-images/b8c0c/b8c0cf2f7bd41b9f3c47931f96cc0fe54761f588" alt=""
AngularJS the bad
- DI (good for testing but creates its own problems)
- Routing (http://angular-route-segment.com/). Simpler than UI-State router.
- Dynamically Typed Templates.
AtScript
AtScript Premier http://goo.gl/Fwczpf
class MyClass {
methodA(name:string):int {
var length:int = name.length;
return length;
}
}
Managing Application Links
linkto
data:image/s3,"s3://crabby-images/c722f/c722f3674bcfbf2f74c8e7eed705030c12ce7e80" alt=""
Managing Application Links
Put it on $rootScope
data:image/s3,"s3://crabby-images/1afba/1afbabf95241c4a7db44bd8366606029aeda4154" alt=""
At Dev Time
Easy to do from controllers
data:image/s3,"s3://crabby-images/67ae8/67ae8787df0765c34d9a9db9a88c35ede54bd029" alt=""
Grunt
Must to manage your frontend.
data:image/s3,"s3://crabby-images/666b6/666b6811654570a8a46f5f193f4ebf34dc63a1d8" alt=""
All it does
- TypeScript -> JS compile
- RequireJS -> single JS concatenation
- SaSS -> CSS compile
- CSS + Vendor CSS -> Single CSS
- Watches this stuff at dev time
TIP
Check in your node_modules folder
- No dev machine setup
- No build time delay
- What happens if NPM is down
- What happens if NPM is exploited
Mocha
Let it do the clicking for you.
Prevents backend regressions and allows easier refactoring.
data:image/s3,"s3://crabby-images/df124/df124966a0bcafe37b2f1b3ad4719e4cee21ce44" alt=""
Mocha
Sample Spec
data:image/s3,"s3://crabby-images/e40a1/e40a1951d99335954a4eb60b6c9a4a7c4823a77e" alt=""
Mocha
- Services are generated and shared between server and client
- compiled TypeScript with `amd` for client and `commonjs` for testing
- Isolate your Create, Get, Expect functions as these are reused
- Use Promises!
Mocha
- Replaced contract equivalent version of:
- $http: using request
- Custom Injector
- Others
data:image/s3,"s3://crabby-images/48726/48726acb7a30a8091d4cb20f13d51cabd36a952f" alt=""
Mocha
Test users setup
data:image/s3,"s3://crabby-images/3b035/3b035260c728a81cd99b843dc09ff04e80829b3a" alt=""
Summary
- TypeScript : Let the compiler work for you
- AngularJS: Community
- SaSS: Don't use CSS directly
- Grunt: Some front-end compile pipeline
- Mocha: Midway Tests are awesome
Picnic Software Frontend
By basarat
Picnic Software Frontend
- 2,676