Jaime Neves
@dejaneves
jaimeneves.com.br
1º Femug-AM
data:image/s3,"s3://crabby-images/cf99f/cf99f3d9d8385232c39bea710594e76374470cdd" alt=""
data:image/s3,"s3://crabby-images/2300e/2300e8efddcccabb35aaeae3ecfe5c1545782d66" alt=""
Project
Empregos Manaus
empregosmanaus.com.br
Project
CheckForce.js
Checkforce.js is a library that helps to perform tasks to test strength of passwords.
data:image/s3,"s3://crabby-images/489b1/489b1505b5f654fbb9563950d0a5c62805f8eb41" alt=""
Tornando a vida mas fácil para dormir tranquilo
1º Femug-AM
Agenda
- Advantages of using AngularJS
- Example of Code
- Single Page Application
Easy to organize your code
jQuery
Easy to organize your code
Template
AngularJS View Template
phonecatApp.controller('PhoneListController', function PhoneListController($scope) {
$scope.phones = [
{
name: 'Nexus S',
snippet: 'Fast just got faster with Nexus S.'
}, {
name: 'Motorola XOOM™ with Wi-Fi',
snippet: 'The Next, Next Generation tablet.'
}, {
name: 'MOTOROLA XOOM™',
snippet: 'The Next, Next Generation tablet.'
}
];
});
<body ng-controller="PhoneListController">
<ul>
<li ng-repeat="phone in phones">
<span>{{phone.name}}</span>
<p>{{phone.snippet}}</p>
</li>
</ul>
</body>
data:image/s3,"s3://crabby-images/c4398/c439880bb26df2a18dca6ae8c366d228b8d1c314" alt=""
Model
And Result
data:image/s3,"s3://crabby-images/b537a/b537a31e3e18ff8c51e0a8eefa500e0bd89d2f0c" alt=""
Directives
data:image/s3,"s3://crabby-images/bc961/bc9615f79305295727033ddf61e4ce536cd05fc5" alt=""
Book: Angularjs in Action
Directives
MyModule.directive('myCustomer', function() {
return {
restrict:'A',
template: 'Name: {{customer.name}} Address:{{customer.address}}'
};
});
<div ng-controller="Controller">
<div my-customer></div>
</div>
HTML Template
Components
Advantages of Components:
-
Simpler configuration than plain directives
-
Promote sane defaults and best practices
- Optimized for component-based architecture
- Writing component directives will make it easier to upgrade to Angular 2
Components
MyModule.
component('phoneList', {
template:
'<ul>' +
'<li ng-repeat="phone in $ctrl.phones">' +
'<span>{{phone.name}}</span>' +
'<p>{{phone.snippet}}</p>' +
'</li>' +
'</ul>',
controller: function PhoneListController() {
this.phones = [
{
name: 'Nexus S',
snippet: 'Fast just got faster with Nexus S.'
}, {
name: 'Motorola XOOM™ with Wi-Fi',
snippet: 'The Next, Next Generation tablet.'
}, {
name: 'MOTOROLA XOOM™',
snippet: 'The Next, Next Generation tablet.'
}
];
}
});
Two-way data-binding
data:image/s3,"s3://crabby-images/772c8/772c8716b1e34952b9c26df2fa5be4399fbc59d2" alt=""
Data Binding in Classical Template Systems
data:image/s3,"s3://crabby-images/5af95/5af95c55681aacfb0e634726f9b0c3477a5a9878" alt=""
Data Binding in Angular Templates
data:image/s3,"s3://crabby-images/b537a/b537a31e3e18ff8c51e0a8eefa500e0bd89d2f0c" alt=""
Factory
myApp.factory('clientId', function clientIdFactory() {
return 'a12345654321x';
});
function factory(name, factoryFn, enforce) {
return provider(name, {
$get: enforce !== false ? enforceReturnValue(name, factoryFn) : factoryFn
});
}
function service(name, constructor) {
return factory(name, ['$injector', function($injector) {
return $injector.instantiate(constructor);
}]);
}
Factory vs Service
var Pessoa = function(nome, idade) {
return {
nome: nome,
idade: idade
}
}
var maria = Pessoa("Maria", 23);
maria.idade; // 23
var Pessoa = function(nome, idade) {
this.nome = nome;
this.idade = idade;
}
var maria = new Pessoa("Maria", 23);
maria.idade; // 23
Single-Page Application (SPAs)
Configure Routes and View
Injecting pages into the mains Layout
The RESTful functionality
Ferramentas
Bower
Instalação de pacotes
NPM
1º FEMUG - AM
By Jaime Neves
1º FEMUG - AM
- 482