SlideShare une entreprise Scribd logo
1  sur  46
Télécharger pour lire hors ligne
Welcome !
I have nothing to o튵䎣er but blood, toil, tears, and
sweat.
W. Churchill, 13 mai 1940
@pierrci
Evolution of Web Apps
https://evolution-of-apps.剭녲rebaseapp.com
David East - Firebase & Angular team
So... Angular !
En 4 mots clés
Framework Javascript
SPA
(o_O)
Google
MVW
Au sujet de MVC / MVVM :
http://www.docdoku.com/blog/2015/02/17/architecturer-ses-applications-js-pattern-mvvm/
http://stackover�ow.com/questions/667781/what-is-the-di튵䎣erence-between-mvc-and-mvvm/
Aujourd'hui, version 1.X - https://angularjs.org/
Demain, version 2.X - https://angular.io/
-
AngularJS however is not an example of developers
maintaining backwards compatibility. It takes
pleasure in starting over. In fact, you can just
about rip up your old Angular apps now. It’s for
your own good.
@EdwardCGordon packtpub.com
La classe non ?
Ready for roller coasters ?
Sans Angular...
<html> 
    <head>
        <title>Index</title> 
    </head> 
    <body>
        Name: <input type="text" id="myInputBox"> 
        Hello <span id="nameSpan"></span> !             
        <script>
</script> 
    </body> 
</html>
 
            var inputElem = document.getElementById("myInputBox"); 
            inputElem.addEventListener('keyup', function() { 
                var text = inputElem.value; 
                document.getElementById("nameSpan").innerHTML = text; 
            }); 
        
Avec Angular !
<html> 
    <head>
        <title>Index</title> 
        <script src="../angular.min.js"></script> 
    </head> 
    <body ng­app> 
        Name: <input type="text" ng­model="nameModel"> 
        Hello {{ nameModel }} ! 
    </body> 
</html>
<html> 
    <head> 
        <title>Index</title> 
        <script src="../angular.min.js"></script> 
    </head> 
    <body ng­app> 
        Name: <input type="text" ng­model="nameModel"> 
        Hello {{ nameModel }} ! 
    </body> 
</html>
ng-app : directive de bootstrap ("démarrage"), indique à angular
où se situe l'application dans la page HTML.
ng-model : directive qui associe ("bind") la valeur d'un champ à
une variable.
{{ nameModel }} : expression angular, elle est évaluée par angular
et son résultat est inséré dans la page.
<demo />
Les modules
<body ng­app="monApplicationAngular">
La valeur passée à ngApp est le nom du module principal de
l'application.
Un module contient les composants de notre application :
controllers, directives, services, 剭녲ltres...
Pour pouvoir ajouter ces composants, il faut déclarer le module côté
javascript :
var app = angular.module("monApplicationAngular", [ 
    "ngRoute", 
    "ngResource", 
    //... 
]); 
// Dans sa forme la plus simple : 
// var app = angular.module("monApplicationAngular", []);
Une fois déclaré, on peut l'appeler et lier des composants :
angular 
    .module("monApplicationAngular") 
    .directive("uneDirective", maDirective); 
     
function maDirective() { 
    //... 
}
Les expressions Angular
<body ng­app="monApplicationAngular"> 
    1 + 2 = {{ 1 + 2 }} 
    Nom de l'utilisateur : {{ user.name }} 
    Loisir n° 3 de l'utilisateur : {{ user.loisirs[2] }} 
</body>
Comment et où déclarer user ?
=> Dans un controller
Les controllers
C'est là que l'on interagit avec les données de la vue
angular 
    .module("monApplicationAngular") 
    .controller("HomeController", HomeController); 
function HomeController() { 
    var vm = this; // vm pour ViewModel 
    vm.user = { 
        name: "Pierric", 
        loisirs: ['ski', 'lecture', 'musique'] 
    } 
}
On "bind" les méthodes et variables qui nous intéressent au this de
HomeController
Il faut penser à déclarer le controller dans le HTML grâce à la
directive ngController
<body ng­app="monApplicationAngular"> 
    <div ng­controller="HomeController as home"> 
        Nom de l'utilisateur : {{ home.user.name }} 
        Loisir n° 3 de l'utilisateur : {{ home.user.loisirs[2] }} 
    </div> 
</body>
On utilise la syntaxe controllerAs, indissociable du binding à
l'instance du controller (le this côté JS), en spéci剭녲ant un alias pour
notre controller : home (arbitraire)
-Do You Like Your Angular Controllers with or without Sugar? @John_Papa
$scope
Dans le javascript, on aurait pu aussi lier le modèle à $scope au lieu
de this, sans utiliser la syntaxe controllerAs :
function HomeController($scope) { 
    $scope.user = { 
        name: "Pierric", 
        loisirs: ['ski', 'lecture', 'musique'] 
    } 
}
Côté HTML :
<div ng­controller="HomeController"> 
    Nom de l'utilisateur : {{ user.name }} 
    Loisir n° 3 de l'utilisateur : {{ user.loisirs[2] }} 
</div>
Les limites de $scope
<div ng­controller="MainCtrl">
    {{ title }} 
    <div ng­controller="AnotherCtrl"> 
        {{ title }} 
        <div ng­controller="YetAnotherCtrl"> 
            {{ title }} 
        </div> 
    </div> 
</div>
On préfèrera limiter $scope à l'utilisation de méthodes qui en
dépendent telles que $watch, $on ou $broadcast
-
function HomeController($scope) { 
    var vm = this; 
    vm.username = "Pierric"; 
    $scope.$on('someEventFiredFromElsewhere', function (event, data) { 
        // do something! 
    }); 
}
Digging into Angular’s “Controller as” syntax @toddmotto
<demo />
Les directives
ngApp, ngController, ngModel, ... sont des directives
Ce sont des marqueurs positionnés sur des éléments du DOM qui
indiquent à angular quel comportement attacher à un élément et/ou
quelle transformation y apporter
De nombreuses directives sont intégrées nativement :
https://code.angularjs.org/1.4.11/docs/api/ng/directive
Directives de template
: insère ou pas un élément dans le DOM en fonction de la
valeur de l'attribut
ngIf
<div ng­if="isVisible">I'm gonna disappear</div>
: permet de parcourir les éléments d'un tableau et
d'a皉푰cher leur valeur
ngRepeat
<div ng­repeat="user in users">{{ user.name }}</div>
: modi剭녲e le contenu d'un élément suivant la valeur d'une
expression
ngSwitch
<div ng­switch="isEditable"> 
    <div ng­switch­when="false">Name : {{ user.name }}</div> 
    <div ng­switch­when="true"><input type="text" ng­model="user.name"></div> 
</div>
Directives de style
/ : modi剭녲e la visibilité d'un élément du DOM
suivant la valeur de l'expression en paramètre
ngShow ngHide
<div ng­hide="hidden">Hello hide</div> 
<div ng­show="hidden">Hello show</div>
: conditionne dynamiquement les classes d'un élément du
DOM suivant la valeur d'expressions
ngClass
<p ng­class="{bold: important, red: error}">Map Syntax Example</p>
: modi剭녲e la valeur de l'attribut disabled suivant
l'expression spéci剭녲ée
ngDisabled
<button ng­disabled="isDisabled">Disabled</button>
Directives d'action
: permet d'appeler une fonction ou d'évaluer une
expression lors d'un clic sur l'élément
ngClick
<div ng­click="click()">Click me!</div> 
<button ng­click="count = count + 1" ng­init="count = 0">Increment</button>
/ : associe des actions à des événements
claviers
ngKeydown ngKeyup
<input type="text" ng­keydown="down()" ng­keyup="up()">
: spéci剭녲e l'action à e튵䎣ectuer pour l'envoi d'un
formulaire. Ne pas combiner avec ngClick !
ngSubmit
<form ng­submit="submit()" ng­controller="SimpleFormController"> 
    <input type="text" ng­model="text" name="text"> 
    <input type="submit" id="submit" value="Submit"> 
</form>
<demo />
Les Filtres
Les 剭녲ltres permettent de formatter et de... 剭녲ltrer (!) les expressions
auxquelles ils sont appliqués :
{{ expression | filter }} 
{{ expression | filter1 | filter2 }} <!­­ Ils peuvent être combinés ­­>
{{ expression | filter:arg1:arg2 }} <!­­ On peut passer des arguments ­­>
Exemples :
{{ 'Mon texte' | uppercase }} 
{{ '25.465' | number:2 | currency:'$'}} <!­­ seulement 2 décimales ­­>
Liste des 剭녲ltres natifs :
https://docs.angularjs.org/api/ng/剭녲lter
Soit le tableau suivant dans un controller:
var jb = {name: 'JB', gender: 'male'}, 
    cyril = {name: 'Cyril', gender: 'male', birth: '1990­11­25'}, 
    agnes = {name: 'Agnes', gender: 'female', birth: '1991­07­22'}, 
    cedric = {name: 'Cedric', gender: 'male', birth: '1992­02­22'}; 
vm.ninjas = [jb, cyril, agnes, cedric];
Avec le HTML suivant :
<p>{{ ninjas | orderBy:'name' | limitTo:2 }}</p> 
<div ng­repeat="ninja in ninjas"> 
    {{ ninja.birth | date:'yyyy' }} 
</div>
On obtiendra :
[ 
    {"name":"Agnes","gender":"female","birth":"1990­07­22"}, 
    {"name":"Cedric","gender":"male","birth":"1990­02­22"} 
] 
1990 
1991 
1992
Le filtre Filter
剭녲lter permet d'appliquer un 剭녲ltre personnalisé aux éléments d'un
tableau
<input type="text" ng­model="searchText"> 
<table id="searchTextResults"> 
    <tbody><tr><th>Name</th><th>Birth date</th></tr> 
    <tr ng­repeat="ninja in ninjas | filter:searchText"> 
        <td>{{ friend.name }}</td> 
        <td>{{ friend.birth | date:'dd/MM/yyyy' }}</td> 
    </tr> 
</tbody></table>
<label>Any: <input ng­model="search.$"></label><br> 
<label>Name only <input ng­model="search.name"></label><br> 
<label>Gender only <input ng­model="search.gender"></label><br> 
<label>Equality <input type="checkbox" ng­model="strict"></label><br> 
<table id="searchObjResults"> 
    <tbody><tr><th>Name</th><th>Gender</th></tr> 
    <tr ng­repeat="ninja in ninjas | filter:search:strict"> 
        <td>{{ ninja.name }}</td> 
        <td>{{ ninja.gender }}</td> 
    </tr> 
</tbody></table>
<demo />
Time for practice !
- Unit 1Learn AngularJS | Codecademy
- Levels 1 / 2 / 3Shaping up with AngularJS | CodeSchool
Créer ses directives
L'avenir du web est aux : découpage des
fonctionnalités en modules réutilisables indépendamment.
Web Components
Les directives sont un avant-goût et permettent d'implémenter une
partie de cette logique.
peut devenir :
<div> 
    <h1 class="title">{{ book.title }}</h1> 
    <h2 class="author">{{ book.author }}</h2> 
    <div class="extract">{{ book.extract }}</div> 
</div>
<book­details data­book="main.book"></book­details>
Fichier bookDetails.directive.js :
angular.module('myApp') 
       .directive('bookDetails', bookDetails);  // camelCase côté JS ! 
        
function bookDetails() { 
    return {            // Une directive retourne un objet de "configuration" 
        restrict: 'E',  // La directive doit être appelée sous forme d'élément 
        scope: {        // On crée un nouveau scope isolé propre à la directive 
            book: '='   // On récupère l'objet passé à l'attribut correspondant 
        }, 
        templateUrl: 'bookDetails.tpl.html',  // Indique où aller chercher le HTML 
    }; 
}
Fichier bookDetails.tpl.html :
<div> 
    <h1 class="title">{{ book.title }}</h1> 
    <h2 class="author">{{ book.author }}</h2> 
    <div class="extract">{{ book.extract }}</div> 
</div>
restrict : indique comment doit être appelée la directive dans le
HTML - A pour attribut, E pour élement et C pour classe CSS. On
peut les combiner, par exemple 'AEC'.
scope : crée un scope isolé pour la directive. On récupère les
éléments du scope englobant via les attributs. '@' pour passer une
valeur (chaîne de caractères), '=' pour du two-way binding sur un
objet.
controller : une directive peut avoir son propre controller.
controllerAs : permet de spéci剭녲er un alias pour le controller,
comme avec ng-controller = ... as ...
bindToController : indissociable de ControllerAs, lie les propriétés à
l'instance du controller plutôt qu'au scope.
... 
controller: function () { 
    var vm = this;     
    vm.selectBook = function () { ... } 
}, 
controllerAs: 'bookDetails', 
bindToController: true 
...
https://docs.angularjs.org/api/ng/service/$compile
<demo />
Time for practice !
- Unit 2Learn AngularJS | Codecademy
- Level 4Shaping up with AngularJS | CodeSchool
Les services
Les services sont des objets dans lesquels on met le code
correspondant à la logique métier de l'application. Ils sont aussi
utilisés pour organiser le code partagé de l'application.
Les services sont :
Lazy : paresseux, ils ne sont instanciés que lorsque l'application en
a besoin
Singletons : ils seront instanciés une seule fois et cette instance
est ensuite utilisée partout
Les services natifs
: permet de faire simplement des requêtes AJAX. Renvoie
une promise avec une callback de succès et une autre d'échec.
$http
$http({method: 'GET', url: '/serverUrl'}) 
    .success(function(data, status, headers, config){ ... }) 
    .error(function(data, status, headers, config){ ... });
: service plus haut niveau, utilisé pour interagir avec des
. Nécessite le module ngResource.
$resource
API REST
{ 'get':    {method:'GET'}, 
  'save':   {method:'POST'}, 
  'query':  {method:'GET', isArray:true}, 
  'remove': {method:'DELETE'}, 'delete': {method:'DELETE'} };
var Poneys = $resource('/races/:raceId/poneys/:poneyId',  
    { raceId: 24, poneyId: '@id'}, { run: { method: 'PUT' }}); 
var fury = Poneys.save({ name: 'Fury Red'});
: rend accessible l'URL de la page actuelle à notre
application et expose plusieurs méthodes.
$location
// avec l'url http://example.com/#/some/path?foo=bar&baz=xoxo 
var path = $location.path(); // => "/some/path" 
var searchObject = $location.search(); // => {foo: 'bar', baz: 'xoxo'}
/ : permettent de wrapper setTimeout et
setInterval dans le cycle de vie de l'application angular.
$timeout $interval
var delayedFn = $timeout(function(){ ... }, 1000) // Après 1 seconde. 
var recurringFn = $interval(function(){ ... }, 1000, 0) // Chaque seconde.
Autres wrappers ($window, $document...) et services natifs :
https://docs.angularjs.org/api/ng/service
Les Promises
Nouveauté de l'EcmaScript 6, implémentée via le service $q.
Utilisée lors de traitements asynchrones tels que les requêtes AJAX
avec $http.
Une promise peut avoir deux résultats : succès ou échec.
$http.get(...) 
    .then(function(data){ 
        // succès, promise résolue 
    }, function(error){ 
        // erreur, promise rejetée 
});
$q
function asyncGreet(name) { 
    var deferred = $q.defer(); // On crée un objet deferred 
    $timeout(function() { // Ici on crée artificiellement un délai 
        deferred.notify('About to greet ' + name + '.'); 
     
        if (okToGreet(name)) { 
            deferred.resolve('Hello, ' + name + '!'); // succès 
        } else { 
            deferred.reject('Greeting ' + name + ' is not allowed.'); // échec 
        } 
    }, 1000); 
     
    return deferred.promise; // On retourne la promise de deferred 
} 
var promise = asyncGreet('Robin Hood'); // La fonction retourne une promise 
promise.then(function(greeting) { 
    alert('Success: ' + greeting); // En cas de succès 
}, function(reason) { 
    alert('Failed: ' + reason); // En cas d'échec 
}, function(update) { 
    alert('Got notification: ' + update); // Indication de progression 
});
<demo />
L'injection de dépendance (DI)
Pour pouvoir utiliser un composant dans un autre, angular utilise un
système d'injection de dépendance.
function HomeController($scope, $http) { ... } 
// function HomeController($http, $scope) { ... } // équivalent !
HomeController.toString(); // "function HomeController($scope, $http) { ... }"
Pour éviter les problèmes en cas de mini剭녲cation du javascript, on
"annote" les composants :
HomeController.$inject = ['$scope', '$http']; 
function HomeController($scope, $http) { ... } // Il vaut mieux garder le même ordre...
Time for practice !
- Unit 3Learn AngularJS | Codecademy
- Level 5Shaping up with AngularJS | CodeSchool
ngRoute
ngRoute est le module angular de base chargé du routage.
Il est composé d'une directive ngView, d'un $routeProvider et de 2
services : $route et $routeParams.
ngView indique quelle partie de la SPA sera mise à jour :
<div ng­view=""></div>
$routeProvider
$routeProvider permet de déterminer les routes de l'application et
de faire le lien entre URL, template et controller.
angular 
    .module("monApplicationAngular") 
    .config(configure); 
     
function configure($routeProvider) { 
    $routeProvider 
        .when('/races/:raceId?', { // raceId est un paramètre facultatif 
            templateUrl: 'races.html', 
            controller: 'RacesController' // Remplace ng­controller="..." 
        }) 
        .when('/', { 
            templateUrl: 'poneys.html', 
            controller: 'PoneysController' 
            controllerAs: 'poneys' // Remplace ng­controller="... as ..." 
        }) 
        .otherwise('/'); // Si l'url ne correspond pas, redirection 
}
$routeParams
Service permettant de déterminer les paramètres de la route.
Combinaison de $location.search() et $location.path().
// Avec une url = http://www.example.com/#/races/13?poney=10 
$routeParams ==> { raceId: "13", poney: "10" }
Time for practice !
- Units 4 / 5Learn AngularJS | Codecademy
Ressources utiles
- ebook - [fr]
chez video2brain - [fr]
par - [fr]
par - [fr]
sur MDN - [fr]
Le guide du développeur
Devenez un ninja avec AngularJS
2 formations vidéos
Formation vidéo AngularJS @gra剭녲kart_fr
Le guide de style Angular @john_papa
Une réintroduction à Javascript

Contenu connexe

Tendances

AngularJS - Présentation (french)
AngularJS - Présentation (french)AngularJS - Présentation (french)
AngularJS - Présentation (french)Yacine Rezgui
 
comprendre angularJS en 10 minutes
comprendre angularJS en 10 minutescomprendre angularJS en 10 minutes
comprendre angularJS en 10 minutesDavid Bo
 
Introduction à Angular 2
Introduction à Angular 2Introduction à Angular 2
Introduction à Angular 2Laurent Duveau
 
Angular JS - Paterne Gaye-Guingnido
Angular JS - Paterne Gaye-Guingnido Angular JS - Paterne Gaye-Guingnido
Angular JS - Paterne Gaye-Guingnido SOAT
 
Débuter avec Rails::API & AngularJS
Débuter avec Rails::API & AngularJSDébuter avec Rails::API & AngularJS
Débuter avec Rails::API & AngularJSFrédéric DUPERIER
 
Apéro techno node.js + AngularJS @Omnilog 2014
Apéro techno node.js + AngularJS @Omnilog 2014Apéro techno node.js + AngularJS @Omnilog 2014
Apéro techno node.js + AngularJS @Omnilog 2014Yves-Emmanuel Jutard
 
Google : Prise en charge de l'Ajax et de l'Angular JS
Google : Prise en charge de l'Ajax et de l'Angular JSGoogle : Prise en charge de l'Ajax et de l'Angular JS
Google : Prise en charge de l'Ajax et de l'Angular JSPeak Ace
 
Partie 2: Angular
Partie 2: AngularPartie 2: Angular
Partie 2: AngularHabib Ayad
 
Symfony with angular.pptx
Symfony with angular.pptxSymfony with angular.pptx
Symfony with angular.pptxEsokia
 
Devoxx France 2015 - Développement web en 2015
Devoxx France 2015 - Développement web en 2015Devoxx France 2015 - Développement web en 2015
Devoxx France 2015 - Développement web en 2015Romain Linsolas
 
Devoxx France 2015 - Se préparer à l'arrivée d'Angular 2
Devoxx France 2015 - Se préparer à l'arrivée d'Angular 2Devoxx France 2015 - Se préparer à l'arrivée d'Angular 2
Devoxx France 2015 - Se préparer à l'arrivée d'Angular 2Romain Linsolas
 
Hello AngularJS - Back to the future
Hello AngularJS - Back to the futureHello AngularJS - Back to the future
Hello AngularJS - Back to the futureOuadie LAHDIOUI
 
Angluars js
Angluars jsAngluars js
Angluars jsRYMAA
 
Partie1 TypeScript
Partie1 TypeScriptPartie1 TypeScript
Partie1 TypeScriptHabib Ayad
 

Tendances (20)

AngularJS - Présentation (french)
AngularJS - Présentation (french)AngularJS - Présentation (french)
AngularJS - Présentation (french)
 
comprendre angularJS en 10 minutes
comprendre angularJS en 10 minutescomprendre angularJS en 10 minutes
comprendre angularJS en 10 minutes
 
Introduction à Angular 2
Introduction à Angular 2Introduction à Angular 2
Introduction à Angular 2
 
Angular JS - Paterne Gaye-Guingnido
Angular JS - Paterne Gaye-Guingnido Angular JS - Paterne Gaye-Guingnido
Angular JS - Paterne Gaye-Guingnido
 
Retour d'experience projet AngularJS
Retour d'experience projet AngularJSRetour d'experience projet AngularJS
Retour d'experience projet AngularJS
 
Débuter avec Rails::API & AngularJS
Débuter avec Rails::API & AngularJSDébuter avec Rails::API & AngularJS
Débuter avec Rails::API & AngularJS
 
Apéro techno node.js + AngularJS @Omnilog 2014
Apéro techno node.js + AngularJS @Omnilog 2014Apéro techno node.js + AngularJS @Omnilog 2014
Apéro techno node.js + AngularJS @Omnilog 2014
 
jQuery vs AngularJS
jQuery vs AngularJS jQuery vs AngularJS
jQuery vs AngularJS
 
Google : Prise en charge de l'Ajax et de l'Angular JS
Google : Prise en charge de l'Ajax et de l'Angular JSGoogle : Prise en charge de l'Ajax et de l'Angular JS
Google : Prise en charge de l'Ajax et de l'Angular JS
 
Partie 2: Angular
Partie 2: AngularPartie 2: Angular
Partie 2: Angular
 
Symfony with angular.pptx
Symfony with angular.pptxSymfony with angular.pptx
Symfony with angular.pptx
 
Test angular 2+
Test angular 2+Test angular 2+
Test angular 2+
 
Présentation Angular 2
Présentation Angular 2 Présentation Angular 2
Présentation Angular 2
 
Devoxx France 2015 - Développement web en 2015
Devoxx France 2015 - Développement web en 2015Devoxx France 2015 - Développement web en 2015
Devoxx France 2015 - Développement web en 2015
 
Introduction à Angular 2
Introduction à Angular 2Introduction à Angular 2
Introduction à Angular 2
 
Devoxx France 2015 - Se préparer à l'arrivée d'Angular 2
Devoxx France 2015 - Se préparer à l'arrivée d'Angular 2Devoxx France 2015 - Se préparer à l'arrivée d'Angular 2
Devoxx France 2015 - Se préparer à l'arrivée d'Angular 2
 
Hello AngularJS - Back to the future
Hello AngularJS - Back to the futureHello AngularJS - Back to the future
Hello AngularJS - Back to the future
 
Angluars js
Angluars jsAngluars js
Angluars js
 
Introduction à Angular
Introduction à AngularIntroduction à Angular
Introduction à Angular
 
Partie1 TypeScript
Partie1 TypeScriptPartie1 TypeScript
Partie1 TypeScript
 

En vedette

Destructeur de documents Kobra 430 TS #Mode d'emploi
Destructeur de documents Kobra 430 TS #Mode d'emploiDestructeur de documents Kobra 430 TS #Mode d'emploi
Destructeur de documents Kobra 430 TS #Mode d'emploiTerface
 
Quelques idees pour Riad de luxe elementaire dans des strategies de Marrakech
Quelques idees pour Riad de luxe elementaire dans des strategies de Marrakech
Quelques idees pour Riad de luxe elementaire dans des strategies de Marrakech
Quelques idees pour Riad de luxe elementaire dans des strategies de Marrakech hotelmarrakech4343
 
Programme du l'archipel
Programme du l'archipelProgramme du l'archipel
Programme du l'archipelEGM16081984
 
Fondation Leo Messi
Fondation Leo MessiFondation Leo Messi
Fondation Leo MessiJerzzy Amkwh
 
Diapositivas pamela rojas web2.0
Diapositivas pamela rojas web2.0Diapositivas pamela rojas web2.0
Diapositivas pamela rojas web2.0Pame Rojas
 
pictures for helena
pictures for helenapictures for helena
pictures for helenafedrocks
 
Ddoc t 2013_0048_deloffre
Ddoc t 2013_0048_deloffreDdoc t 2013_0048_deloffre
Ddoc t 2013_0048_deloffreOmarSahraoui014
 
Larousse postres pierre herme (2 parte)
Larousse postres pierre herme (2 parte)Larousse postres pierre herme (2 parte)
Larousse postres pierre herme (2 parte)jtviloria
 
La videosurveillance est-elle_un_outil_de_securite_et_de_gestion_efficace_fr
La videosurveillance est-elle_un_outil_de_securite_et_de_gestion_efficace_frLa videosurveillance est-elle_un_outil_de_securite_et_de_gestion_efficace_fr
La videosurveillance est-elle_un_outil_de_securite_et_de_gestion_efficace_frabdoulaye camara
 
MelBIM Sample
MelBIM SampleMelBIM Sample
MelBIM SampleMelBIM
 
Système WB pour un renfort à la traction perpendiculaire
Système WB pour un renfort à la traction perpendiculaireSystème WB pour un renfort à la traction perpendiculaire
Système WB pour un renfort à la traction perpendiculaireSFS intec
 
Atelier libre de droits
Atelier libre de droitsAtelier libre de droits
Atelier libre de droitsvlbj
 

En vedette (20)

Destructeur de documents Kobra 430 TS #Mode d'emploi
Destructeur de documents Kobra 430 TS #Mode d'emploiDestructeur de documents Kobra 430 TS #Mode d'emploi
Destructeur de documents Kobra 430 TS #Mode d'emploi
 
Tarotmag n°08
Tarotmag n°08Tarotmag n°08
Tarotmag n°08
 
Imprimante à étiquettes
Imprimante à étiquettesImprimante à étiquettes
Imprimante à étiquettes
 
Quelques idees pour Riad de luxe elementaire dans des strategies de Marrakech
Quelques idees pour Riad de luxe elementaire dans des strategies de Marrakech
Quelques idees pour Riad de luxe elementaire dans des strategies de Marrakech
Quelques idees pour Riad de luxe elementaire dans des strategies de Marrakech
 
Programme du l'archipel
Programme du l'archipelProgramme du l'archipel
Programme du l'archipel
 
Fondation Leo Messi
Fondation Leo MessiFondation Leo Messi
Fondation Leo Messi
 
Hanae guennouni
Hanae guennouniHanae guennouni
Hanae guennouni
 
Monnaie ancienne
Monnaie ancienneMonnaie ancienne
Monnaie ancienne
 
Tarot Mag 23
Tarot Mag 23Tarot Mag 23
Tarot Mag 23
 
Diapositivas pamela rojas web2.0
Diapositivas pamela rojas web2.0Diapositivas pamela rojas web2.0
Diapositivas pamela rojas web2.0
 
pictures for helena
pictures for helenapictures for helena
pictures for helena
 
Réaliser des étiquettes
Réaliser des étiquettesRéaliser des étiquettes
Réaliser des étiquettes
 
Ddoc t 2013_0048_deloffre
Ddoc t 2013_0048_deloffreDdoc t 2013_0048_deloffre
Ddoc t 2013_0048_deloffre
 
Classement National FFT 2015
Classement National FFT 2015Classement National FFT 2015
Classement National FFT 2015
 
Larousse postres pierre herme (2 parte)
Larousse postres pierre herme (2 parte)Larousse postres pierre herme (2 parte)
Larousse postres pierre herme (2 parte)
 
La videosurveillance est-elle_un_outil_de_securite_et_de_gestion_efficace_fr
La videosurveillance est-elle_un_outil_de_securite_et_de_gestion_efficace_frLa videosurveillance est-elle_un_outil_de_securite_et_de_gestion_efficace_fr
La videosurveillance est-elle_un_outil_de_securite_et_de_gestion_efficace_fr
 
MelBIM Sample
MelBIM SampleMelBIM Sample
MelBIM Sample
 
Système WB pour un renfort à la traction perpendiculaire
Système WB pour un renfort à la traction perpendiculaireSystème WB pour un renfort à la traction perpendiculaire
Système WB pour un renfort à la traction perpendiculaire
 
Atelier libre de droits
Atelier libre de droitsAtelier libre de droits
Atelier libre de droits
 
La protection contre les représailles pour les employés du secteur public féd...
La protection contre les représailles pour les employés du secteur public féd...La protection contre les représailles pour les employés du secteur public féd...
La protection contre les représailles pour les employés du secteur public féd...
 

Similaire à Intro à angular

vue j'avais pas vu !!
vue j'avais pas vu !!vue j'avais pas vu !!
vue j'avais pas vu !!Manuel Adele
 
Vue, j’avais pas vu !
Vue, j’avais pas vu !Vue, j’avais pas vu !
Vue, j’avais pas vu !Bruno Bonnin
 
Cours yeoman backbone box2d
Cours yeoman backbone box2dCours yeoman backbone box2d
Cours yeoman backbone box2dhugomallet
 
Atelier autour de UWA à ParisWeb 2007
Atelier autour de UWA à ParisWeb 2007Atelier autour de UWA à ParisWeb 2007
Atelier autour de UWA à ParisWeb 2007Netvibes
 
Play Framework - Toulouse JUG - nov 2011
Play Framework - Toulouse JUG - nov 2011Play Framework - Toulouse JUG - nov 2011
Play Framework - Toulouse JUG - nov 2011Sylvain Wallez
 
Conception de code javascript cote client dans la continuité du renouveau du web
Conception de code javascript cote client dans la continuité du renouveau du webConception de code javascript cote client dans la continuité du renouveau du web
Conception de code javascript cote client dans la continuité du renouveau du webSOAT
 
Paris ember js lab #6 - Taking over server-side rendering websites
Paris ember js lab #6 - Taking over server-side rendering websitesParis ember js lab #6 - Taking over server-side rendering websites
Paris ember js lab #6 - Taking over server-side rendering websitesGuillaume Gérard
 
Café Numérique Arlon S03#02: Je code mon blog (EU code week Arlon)
Café Numérique Arlon S03#02: Je code mon blog (EU code week Arlon)Café Numérique Arlon S03#02: Je code mon blog (EU code week Arlon)
Café Numérique Arlon S03#02: Je code mon blog (EU code week Arlon)Café Numérique Arlon
 
ENIB cours CAI Web - Séance 4 - Frameworks/Spring - Cours
ENIB cours CAI Web - Séance 4 - Frameworks/Spring - CoursENIB cours CAI Web - Séance 4 - Frameworks/Spring - Cours
ENIB cours CAI Web - Séance 4 - Frameworks/Spring - CoursHoracio Gonzalez
 
A la découverte de vue.js
A la découverte de vue.jsA la découverte de vue.js
A la découverte de vue.jsBruno Bonnin
 
Jug summer camp 2017 - Vue.js, même un dev java peut en faire !
Jug summer camp 2017 - Vue.js, même un dev java peut en faire !Jug summer camp 2017 - Vue.js, même un dev java peut en faire !
Jug summer camp 2017 - Vue.js, même un dev java peut en faire !Bruno Bonnin
 
Aperçu de RequireJS
Aperçu de RequireJSAperçu de RequireJS
Aperçu de RequireJSVISEO
 
cours developpement web javascript 2023/2024
cours developpement web javascript 2023/2024cours developpement web javascript 2023/2024
cours developpement web javascript 2023/2024YounesOuladSayad1
 
Gwt fast overview_v1
Gwt fast overview_v1Gwt fast overview_v1
Gwt fast overview_v1David Herviou
 

Similaire à Intro à angular (20)

vue j'avais pas vu !!
vue j'avais pas vu !!vue j'avais pas vu !!
vue j'avais pas vu !!
 
Vue, j’avais pas vu !
Vue, j’avais pas vu !Vue, j’avais pas vu !
Vue, j’avais pas vu !
 
Cours yeoman backbone box2d
Cours yeoman backbone box2dCours yeoman backbone box2d
Cours yeoman backbone box2d
 
Atelier autour de UWA à ParisWeb 2007
Atelier autour de UWA à ParisWeb 2007Atelier autour de UWA à ParisWeb 2007
Atelier autour de UWA à ParisWeb 2007
 
Play Framework - Toulouse JUG - nov 2011
Play Framework - Toulouse JUG - nov 2011Play Framework - Toulouse JUG - nov 2011
Play Framework - Toulouse JUG - nov 2011
 
Backbonejs presentation
Backbonejs presentationBackbonejs presentation
Backbonejs presentation
 
Support cours angular
Support cours angularSupport cours angular
Support cours angular
 
[Tuto] Big datatrack : Web Tracker
[Tuto] Big datatrack : Web Tracker[Tuto] Big datatrack : Web Tracker
[Tuto] Big datatrack : Web Tracker
 
Conception de code javascript cote client dans la continuité du renouveau du web
Conception de code javascript cote client dans la continuité du renouveau du webConception de code javascript cote client dans la continuité du renouveau du web
Conception de code javascript cote client dans la continuité du renouveau du web
 
Paris ember js lab #6 - Taking over server-side rendering websites
Paris ember js lab #6 - Taking over server-side rendering websitesParis ember js lab #6 - Taking over server-side rendering websites
Paris ember js lab #6 - Taking over server-side rendering websites
 
Café Numérique Arlon S03#02: Je code mon blog (EU code week Arlon)
Café Numérique Arlon S03#02: Je code mon blog (EU code week Arlon)Café Numérique Arlon S03#02: Je code mon blog (EU code week Arlon)
Café Numérique Arlon S03#02: Je code mon blog (EU code week Arlon)
 
Angular retro
Angular retroAngular retro
Angular retro
 
ENIB cours CAI Web - Séance 4 - Frameworks/Spring - Cours
ENIB cours CAI Web - Séance 4 - Frameworks/Spring - CoursENIB cours CAI Web - Séance 4 - Frameworks/Spring - Cours
ENIB cours CAI Web - Séance 4 - Frameworks/Spring - Cours
 
A la découverte de vue.js
A la découverte de vue.jsA la découverte de vue.js
A la découverte de vue.js
 
Jug summer camp 2017 - Vue.js, même un dev java peut en faire !
Jug summer camp 2017 - Vue.js, même un dev java peut en faire !Jug summer camp 2017 - Vue.js, même un dev java peut en faire !
Jug summer camp 2017 - Vue.js, même un dev java peut en faire !
 
react-fr.pdf
react-fr.pdfreact-fr.pdf
react-fr.pdf
 
Spring MVC
Spring MVCSpring MVC
Spring MVC
 
Aperçu de RequireJS
Aperçu de RequireJSAperçu de RequireJS
Aperçu de RequireJS
 
cours developpement web javascript 2023/2024
cours developpement web javascript 2023/2024cours developpement web javascript 2023/2024
cours developpement web javascript 2023/2024
 
Gwt fast overview_v1
Gwt fast overview_v1Gwt fast overview_v1
Gwt fast overview_v1
 

Intro à angular