Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.
-
Upload
binary-studio -
Category
Software
-
view
192 -
download
0
Transcript of Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.
![Page 1: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/1.jpg)
JS & UI Applications Design Patterns
Binary Academy 2014 Semenistyi Mykyta
![Page 2: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/2.jpg)
Design Pattern
● Patterns are proven solutions
● Patterns can be easily reused
● Patterns can be expressive
![Page 3: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/3.jpg)
DRY
Don’t Repeat Yourself
WET
![Page 4: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/4.jpg)
General and JS-specific Patterns
![Page 5: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/5.jpg)
![Page 6: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/6.jpg)
Immediately Invoked Function Expression (IIFE)
![Page 7: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/7.jpg)
Module
● Lack of access modifiers;
● Global namespace polluting;
● Code structuring.
problems to solve
![Page 8: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/8.jpg)
Moduleplain object
![Page 9: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/9.jpg)
ModuleIIFE
![Page 10: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/10.jpg)
Revealing Module
● Module is not explicit
● Better code structuring.
problems to solve
![Page 11: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/11.jpg)
Revealing Moduleexample
![Page 12: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/12.jpg)
Factoryexample
![Page 13: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/13.jpg)
Factorywhen to use
● When our object or component setup involves a high level of complexity
● We need to easily generate different instances of objects depending on the
environment
● Working with many small objects that share the same properties
● Objects need only satisfy an API contract (aka, duck typing) to work
![Page 14: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/14.jpg)
Facade
● API Complexity
![Page 15: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/15.jpg)
Mixin
![Page 16: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/16.jpg)
Mixin
![Page 17: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/17.jpg)
Publish/Subscribe
![Page 18: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/18.jpg)
Publish/Subscribe
![Page 19: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/19.jpg)
Mediator
![Page 20: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/20.jpg)
User Interface Patterns
![Page 21: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/21.jpg)
![Page 22: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/22.jpg)
DOM-oriented
![Page 23: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/23.jpg)
MVVM (Model-View-ViewModel)
![Page 24: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/24.jpg)
MVVM (Model-View-ViewModel)
![Page 25: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/25.jpg)
MVVM (Model-View-ViewModel)
![Page 26: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/26.jpg)
MVVM With Looser Data-Bindings
![Page 27: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/27.jpg)
MVVM With Looser Data-Bindings
![Page 28: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/28.jpg)
MVC
![Page 29: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/29.jpg)
Angular
![Page 30: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/30.jpg)
Angular
![Page 31: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/31.jpg)
React
![Page 32: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/32.jpg)
React
![Page 33: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/33.jpg)
React
![Page 34: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/34.jpg)
MVC (Model-View-Controller)
MV* (Model-View-*) | Presenter
![Page 35: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/35.jpg)
Backbone
![Page 36: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/36.jpg)
Modular Patterns
![Page 37: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/37.jpg)
AMD
![Page 38: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/38.jpg)
CommonJS
![Page 39: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/39.jpg)
UMDjsAMD
CommonJS
Sadness
![Page 40: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/40.jpg)
RequireJS
![Page 41: Binary Studio Academy PRO. JS course. Lecture 1. UI Architecture.](https://reader038.fdocuments.in/reader038/viewer/2022103018/558b9e99d8b42a445b8b45eb/html5/thumbnails/41.jpg)
ES Harmony