官术网_书友最值得收藏!

Components in action

Enough of theory! Let's build a component tree based on the class hierarchy illustrated in the preceding diagram. This way, we will demonstrate how we can take advantage of the composite pattern for building a user interface using simplified syntax. We will take a look at a similar example in the context of Angular in Chapter 5, Getting Started with Angular Components and Directives:

Composite c1 = new Composite(); 
Composite c2 = new Composite(); 
Composite c3 = new Composite(); 
 
c1.components.push(c2); 
c1.components.push(c3); 
 
Leaf l1 = new Leaf(); 
Leaf l2 = new Leaf(); 
Leaf l3 = new Leaf(); 
 
c2.components.push(l1); 
c2.components.push(l2);  
c3.components.push(l3); 

The preceding pseudocode creates three instances of the Composite class and three instances of the Leaf class. The c1 instance holds references to c2 and c3 inside the components list. The c2 instance holds references to l1 and l2, and c3 holds reference to l3:

Figure 6

The preceding diagram is a graphical representation of the component tree we built in the snippet. This is a simplified version of what the view in the modern JavaScript frameworks looks like. However, it illustrates the very basics of how we can compose directives and components. For instance, in the context of Angular, we can think of directives as instances of the Leaf class (since they don't own view and, thus, cannot compose other directives and components) and components as instances of the Composite class.

If we think more abstractly for the user interface in AngularJS, we can notice that we used quite a similar approach. The templates of our views compose different directives together in order to deliver a fully functional user interface to the end user of our application.

主站蜘蛛池模板: 富阳市| 娄底市| 江阴市| 浦县| 鲁山县| 铜梁县| 通化市| 工布江达县| 鄂尔多斯市| 临泽县| 安乡县| 建瓯市| 石景山区| 济宁市| 古交市| 文登市| 香港 | 厦门市| 铜鼓县| 个旧市| 唐山市| 长乐市| 和林格尔县| 镇雄县| 察雅县| 苏尼特右旗| 永川市| 阜康市| 富蕴县| 隆子县| 萨嘎县| 瓮安县| 封开县| 新安县| 来安县| 正镶白旗| 无极县| 奉化市| 桦甸市| 桃园市| 扎囊县|