语言选择
无类型
ES5是Angular 1 所使用的语言,无需编译;
ES6/ES2015 包含最新语言的特性,比如classes,(模块的)import,export,ES6解构赋值,简单但有效的let 声明。它可以通过使用Babel 编译器来让所有浏览器兼容。
有类型
TypeScript支持类型。它是JavaScript的演化,采用JavaScript的标准并且增加了一些新特性。口头禅是JavaScript is a valid TypeScript。Angular team在用TypeScript写Angular 2。Most notably(显著的,尤其),它加入了接口和类型。它最大的优势就是在我们写代码的时候,可以检测错误。
Dart 是使用最少的。
关系
ES6/ES2015 是ES5的超集,TypeScript是ES6的超集。TypeScript采用了刚出现的标准例如decorators。
Components
Components是LOGIC,template是渲染。
首先导入Component 从angular2/core,得到Component 对象
data:image/s3,"s3://crabby-images/ddc0b/ddc0bdab27e144e9b72bca89098c0b2a0e1f040f" alt=""
component.png
使用模板的2种方法:
data:image/s3,"s3://crabby-images/357c6/357c69c871f932ef0b64331dee2057fc2aaab6f4" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/a10dd/a10dd54f0c9874c0f520dd967c7a81016f72763d" alt=""
Paste_Image.png
然后定义一个类StoryComponent ,story 是 property ,会在template中展现,接着
data:image/s3,"s3://crabby-images/685b0/685b072c623ce7192338ce183b638a6a5d2ec51a" alt=""
decorator.png
利用装饰器去装饰StoryComponent 类。(装饰器是metadata(描述组件))
data:image/s3,"s3://crabby-images/cfbb8/cfbb87f8edf61fbc04604101799beff162a15663" alt=""
QQ截图20160616100103.png
选择器是一个HTML element
data:image/s3,"s3://crabby-images/8d68c/8d68cbcf8f32a508814fd783e0bfb4baddd05495" alt=""
QQ截图20160616100316.png
data:image/s3,"s3://crabby-images/015c6/015c68ac34d01c597b7e008dd3fb72c1425d2678" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/e87c5/e87c5fef833b36b285f12cc4feb5b22ddf57a4e2" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/93219/93219f67d2f57967c82cf329278c5e16261c5eff" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/b2655/b2655f127899f4a82ef713408637fa73f208492c" alt=""
Paste_Image.png
Root component 可能是整个应用的container 或者shell ,在里面有其他东西。
data:image/s3,"s3://crabby-images/f9770/f977012754377dd423cdf5fd5e169ed1eed00948" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/8024b/8024b74db3466c058d3e066c4750bea647ff1e0d" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/bed13/bed13337c30c1f273e1c99dfdcac91355860803b" alt=""
bootstrap.png
首先导入模块,然后调用bootstrap函数,传入入口构件(整个应用的父构件)。
Structural Built-In Directives
data:image/s3,"s3://crabby-images/f26a9/f26a9aec5c30900c664ae81b3f3d4d0b32b5e412" alt=""
Paste_Image.png
ngFor小驼峰法
变量一般用小驼峰法标识。驼峰法的意思是:除第一个单词之外,其他单词首字母大写。
data:image/s3,"s3://crabby-images/8c407/8c4076ef392546a6a766352390c5b5570540a8c3" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/59bce/59bce77f16e79db1fa02a42731abe9e9b2ee1c88" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/1f0f1/1f0f127999a30ea89d3f4e334d0d78fe36f8c1ae" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/332ee/332eee0437a3420dc55ad53be89696c38f63aac6" alt=""
Paste_Image.png
ngIf 改变结构 :h3 不会显示,如果vehicles的长度为0。
data:image/s3,"s3://crabby-images/9df29/9df29a5a887c0f50ade680a400d1c3d7f1318434" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/e699b/e699bd4962ab5953065e8a8c3c60b4d8a6fc118b" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/26988/2698891c99969b244551d6083d3a04db8f6f6326" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/94241/9424139907b40b131297d98ce463458d1a749980" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/91a40/91a40e972238addab2f0ab2d2f20ba97ab9aa88e" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/23a62/23a62c4e63784afe5f8153e326a014a875aa8851" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/c2acc/c2acce7ee8fbbb5ff1a43416ea3afc3951b6a3aa" alt=""
Paste_Image.png
Metadata
data:image/s3,"s3://crabby-images/9f83b/9f83bad097e1d9733a1388fccf6df05a04baca65" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/04196/041966374e0fd406cfa49e7a891c0adc2a4535b4" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/a11a2/a11a2fe816307579ac0c9c5aebc8ae4604786a6c" alt=""
Paste_Image.png
因此上面这些无需导入,如果是自定义的子组件需要导入
data:image/s3,"s3://crabby-images/78624/786240c7b111173cc65de8f96eb69e2f55aba766" alt=""
Paste_Image.png
template 和style 有2种方式可以使用:inLine or embedded(嵌入)
data:image/s3,"s3://crabby-images/5acf2/5acf276ad4436b72d3601b435fda27edfe75af08" alt=""
Paste_Image.png
plural:复数的
data:image/s3,"s3://crabby-images/d2dd6/d2dd64d6b79eb33f508f1ef8566f76919cb3d65d" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/7c0c8/7c0c8a9c34c93f46ca2fcda2bba2e511d6d2b9f1" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/7ba0c/7ba0c130b5ee243ca52072330133c3571eaf2ba6" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/52647/526470ff9f34d223546c67f9ffbb6760e0dcbc51" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/c9f4b/c9f4b5f99a87848068908974d54c588b64af034f" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/ae970/ae9704ca1f66ee900d442fb50af8ea622652950e" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/1bd81/1bd814ea15ad6ca0e832c25959b72d996b1259de" alt=""
Paste_Image.png
estate :身份
a patch of :一片
directives:声明使用其他组件
data:image/s3,"s3://crabby-images/894c7/894c7df32b3cf5ff8006717af115e693b9940282" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/05e96/05e96a951a33115f7ed1063348a49641776c9eb6" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/b2c31/b2c317da62d524f997d56adec258d229c7015a88" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/67603/67603b67779ec40dab72549aa53631e0d989425e" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/a4a2e/a4a2e0a00efbfe006a95266052c300efbafdc00e" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/8caea/8caea86c0eb7098424770f7042699007b08a3705" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/9a7ee/9a7eebf271cf73cb9c1fd9f0807ca9f3ac6a1e43" alt=""
Paste_Image.png
Output 装饰器,有一个member named changed
data:image/s3,"s3://crabby-images/335a3/335a38364443365e5e8b7f892a301501077ca393" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/01f1c/01f1cdcb62ab6382175bef8669ebd37cce663adf" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/9dc5e/9dc5ec15839325e086e304c772791ee444405fce" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/b28e1/b28e185b5c92a74a324c202a0962d6c12d78e108" alt=""
Paste_Image.png
@Input()
data:image/s3,"s3://crabby-images/603b3/603b319cfb5587ccd73ec8b5b073ce1e7b2347c3" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/f27c2/f27c2c763b911c1811df03c79f8e47dd8743c928" alt=""
Paste_Image.png
Input and Output
data:image/s3,"s3://crabby-images/4476a/4476ac23844bb8c170dd29e5dfc3593e3c125fc9" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/f073a/f073a2f3c487c311bfd4ef0534f4200c56c4c7de" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/e0a4a/e0a4acbf536bbc38ef90ca6aae4c5dd605b1ebe3" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/3987c/3987c17c24f793ab437a1450327e587d6068f2af" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/b7e11/b7e1168d0ec8ce309d418fe42d975ca0807871ba" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/08ed7/08ed70a0a279c3989d359dcd1b806afe4f85f4a7" alt=""
Paste_Image.png
emit 后,父组件可以hear from it.
data:image/s3,"s3://crabby-images/b46e2/b46e246f97d9c00f2abe7081ff6ef60e4c7f73dc" alt=""
Paste_Image.png
Data Binding
从component 里获得数据,把数据传送到(get over to )DOM(view) 。有多种方法:
data:image/s3,"s3://crabby-images/ec02e/ec02ef162eae45057223bd5c4922731b3187c5a9" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/e064e/e064e81ad487e7c2d6a236ae29df53f967534b63" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/7b95f/7b95ffc8ee0152e71ab39f762b8c81c58eb61819" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/64122/64122298fec39cbf0a92420deadea4435ca2eb89" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/f75f2/f75f2e818a956a4bb6ce0a25bc228b6205253f66" alt=""
Paste_Image.png
Interpolation(插值法)
curly braces(花括号)
data:image/s3,"s3://crabby-images/8a550/8a5503c2734c5d08060ec5bd24f43a45c359d80f" alt=""
Paste_Image.png
1 Way Binding
use square brackets around a property
data:image/s3,"s3://crabby-images/b7ac0/b7ac0c7ef5c4b4b14aa942f27adee74757d06561" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/306d8/306d85c1317667df186fd49ce949a6f3d4a6cc6e" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/b7cb8/b7cb8ff3201a7eeb945bd3d7dd4b92cd5acf0824" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/a444f/a444f9a29549145a754a6a25fcad4b35ca1830a5" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/ab6a7/ab6a722f5e80ab05955ecdbb4601a180ad6f303c" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/fd673/fd6739537243a144d62f1874fe0c3da2d9fbfc63" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/44dc6/44dc64e2edfc58284626e920ddeb21f62d8dbd7b" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/c57bb/c57bbf28945d62f7ff990a1155208a99fab21d92" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/12604/12604389757857d8e93aa4716c5524e8294fb58e" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/b6e99/b6e99e529916cf7335190604473585cc1b0cff35" alt=""
Paste_Image.png
不是 attributes.attributes初始化DOM properties。
Event Binding
data:image/s3,"s3://crabby-images/68dae/68daeab6bbed2a3abc2a06062bdb7a9e8ebd54c9" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/3bed9/3bed9b560a903beb9225905f5d84b6abea322394" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/d743e/d743e8a0b8c467099f3e3070893f15ee19110ea8" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/32b0b/32b0b162f937ddd0374b20e310d3909145948c7b" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/2c54c/2c54c7a297214dcd3b2258062b5e6a362a7d8007" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/ff81e/ff81e2ed4c0c2772bf5da4812e466659fb308207" alt=""
Paste_Image.png
2 Way Binding
data:image/s3,"s3://crabby-images/7aac9/7aac95ba60657434e393218ad6a42dc89b0334bc" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/86755/86755de0bb5ca66cd0adf6c3916e094ca13f0559" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/9c8de/9c8de95a541a55e6aad2785af8780b19ddb8a84a" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/fdcdb/fdcdb6f2ae58adaabb9889ed0e0504dce95811f0" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/bdbdc/bdbdce0a3a278cf0e15d37d362aad45a42694374" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/ff881/ff8813853a460106c140ef445675bca5c7069807" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/6ed19/6ed1990a50c80f10c92d5c259e5d7e18586d8944" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/b0eb9/b0eb9b7d51768bbc5ca4cace829866138d4eb4b4" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/d2c02/d2c0293eb2ddef16929c86f02bd5fcf1fb998c87" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/8e316/8e3164d526e7fd7e5befc3f8d61a4c10f30afc08" alt=""
Paste_Image.png
value property?难道不是attribute?
Remove the Need for Many Directives (Fewer Built-in Directives )
data:image/s3,"s3://crabby-images/86b96/86b966eab77ba360b313523567c09050cf28b2ab" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/72f57/72f5783dae1216ada81d6cf74b3b375375f8c7c7" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/22a79/22a7927ad5ae20bb77bd8d3f5c7ae43ea1c1a40d" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/42854/42854d7100d0b2cd8409559887a4e4b5d80a7e14" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/3e669/3e66965eea505d4d5798805f01251b86ad1a45d4" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/281ba/281ba30f5dd647f7471114c60d49cb5dcfee6a29" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/a38fa/a38fab9dd22ca9668a15dc50e69b01512f863d35" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/708ff/708ff92f6266cedda6b3c6a62db75a57b35b9501" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/c5c95/c5c959a8cdfc36682cf101d313768b6cca3a1511" alt=""
Paste_Image.png
data:image/s3,"s3://crabby-images/3c217/3c21744d15200d3d56e617cd3198d08ae0c3dda1" alt=""
Paste_Image.png
网友评论