-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathintroAngular.html
128 lines (128 loc) · 4.6 KB
/
introAngular.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>AngularJs Slides</title>
<!-- Reveal Js -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/reveal.js/3.0.0/css/reveal.min.css">
<!-- Reveal theme -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/reveal.js/3.0.0/css/theme/league.css">
</head>
<body>
<div class="reveal">
<div class="slides">
<section>
<a href="https://angularjs.org/">
<img src="https://angularjs.org/img/ng-logo.png"/>
</a>
<p>HTML enhanced for web apps!</p>
</section>
<section>
<h1>AngularJS</h1>
<p class="fragment">Framework para páginas web dinámicas</p>
<p class="fragment">Extiende la sintaxis de HTML para expresar componentes de forma clara.</p>
<p class="fragment">Inyección de dependencias y databinding</p>
<p class="fragment">Agnóstico del backend</p>
<p class="fragment">Crea nuevas construcciones HTML a través de directivas</p>
<p class="fragment">Enfocado a aplicaciones CRUD</p>
</section>
<section>
<h1>¿Cómo funciona?</h1>
<p class="fragment">Ligado de datos -databinding-</p>
<p class="fragment">Estructuras de control en el DOM</p>
<p class="fragment">Soporte para formularios y validación de los mismos</p>
<p class="fragment">Manejo de eventos del DOM</p>
<p class="fragment">Agrupación de HTML en componentes reusables</p>
</section>
<section>
<section>
<h1>Conceptos básicos</h1>
</section>
<section>
<h1>Template</h1>
<p>HTML con anotaciones especiales, también conocido como partial</p>
</section>
<section>
<h1>Directive</h1>
<p>Extiende el HTML con atributos y elementos personalizados</p>
</section>
<section>
<h1>Model</h1>
<p>Los datos mostrados y con los que el usuario tiene interacción</p>
</section>
<section>
<h1>Scope</h1>
<p>Contexto donde se almacena el modelo para ser accesado por controladores, directivas y expresiones</p>
</section>
<section>
<h1>Compiler</h1>
<p>Analiza la plantilla e instancia directivas y expresiones</p>
</section>
<section>
<h1>Filter</h1>
<p>Da formato al valor de una expresión para mostrarla al usuario</p>
</section>
<section>
<h1>View</h1>
<p>Lo que el usuario ve, puede ser la plantilla</p>
</section>
<section>
<h1>Data binding</h1>
<p>Sincronización automática entre el modelo y la vista - two-way data binding-</p>
<p>Cualquier cambio en la vista es reflejado de inmediato en el modelo y viceversa.</p>
<p>El modelo es la única fuente confiable del estado de la aplicación. Ya que la vista es la proyección del modelo, el controlador está aislado de la vista.</p>
</section>
<section>
<h1>Controller</h1>
<p>Lógica de negocio detrás de la vista</p>
</section>
<section>
<h1>Dependency injection</h1>
<p>Crea y liga objetos y funciones</p>
</section>
<section>
<h1>Injector</h1>
<p>Contenedor de injección de dependencias</p>
</section>
<section>
<h1>Module</h1>
<p>Contenedor para distintas partes de una app, útil para la agrupación de elementos de la misma índole o que están muy relacionados entre sí</p>
</section>
<section>
<h1>Service</h1>
<p>Lógica de negocio reusable, independiente de la vista</p>
</section>
</section>
<section>
<h1>bootstrap</h1>
<section>
<p class="fragment">Proceso para la configuración de la aplicación</p>
<ul>
<li class="fragment">Inyección de dependencias</li>
<li class="fragment">Creación del scope principal: $rootScope</li>
<li class="fragment">procesamiento del DOM, iniciado por la directiva ngApp</li>
<li class="fragment"><a href="examples/bootstraping.html" target="_blank">ejemplo bootstrap</a></li>
</ul>
</section>
</section>
<section>
<h1>Anotaciones</h1>
<p>Angular usa 3 formas de anotación</p>
<ul>
<li>Notación de arreglo en línea</li>
<li>Notación usando $inject</li>
<li>Notación implícita</li>
<li><a href="examples/controller/app.js" target="_blank">ver ejemplo</a></li>
</ul>
</section>
<section>
<h1>Angular en acción</h1>
</section>
</div>
</div>
<script type="text/javascript" src="https://cdn.jsdelivr.net/reveal.js/3.0.0/js/reveal.min.js"></script>
<script>
Reveal.initialize();
</script>
</body>
</html>