SlideShare a Scribd company logo
AngularJs Best Practice
for Enterprise development and
distributed Teams
#angularconf15
Matteo
Scandolo
FE Developer
Team Leader
Code Quality and Maintainability
@_teone
Enterprise?
for Enterprise development …
big
complex
fluid teams
multiple developers
system integrations
Distributed?
… distributed Teams
communication delays
10 rules
to improve your Angular project
#angularconf15
#1
Planning
- Constraints
- Technical Choices
- Application Architecture
- Modules
- Shared Method
- Dependencies
- Guidelines
- Tooling
Immagine dello schema di un progetto
Npm Scripts
#2
Setup
README.md
- Dev Environment
- Deploy
- Tests
- Styleguide*
- Environment Configurations*
- Documentation*
- Contributors*
#3
Styleguide
Force devs to write similar code
- Js styleguide
- Air Bnb
- Angular Styleguide
- Jhon Papa
with a styleguide
with no styleguide
Dev Speed
ES Lint
Pluggable linting utility
- Configurable (Json, Yml)
- Pluggable (as npm packages)
- Extendable
- custom rules
- yeoman generator
ES Lint
ES Lint
Force
#4
Tests
Why are they so important?
- Prevent regressions
- Reduce Bugs
- Code enhancement
- Document features
Karma + Jasmine
Karma
- Test Runner
Jasmine
- Assetion Library
PhantomJs
- Headless browser
The Old Way...
The Clean Way
#5
Documentation
Not talking about high-level
documentation
Technical Docs
- List all available methods
- Teach how to use them
- Specify parameter type
- Provide Examples
- Can do more?
REST API
Build a representation
of your restfull API
- Interactive documentation
- Client SDK generation
REST API
REST API
REST API
REST API
Can generate ngResouces
automatically!
- signalfx/swagger-angular-client
- swagger-api/swagger-codegen
NG DOC
ngDoc
- Extend jsDoc
- Browsable Documentation
- Describe the app API
- Provide usage examples
NG DOC
What can we describe:
- Docs template (@ngdoc)
- Name
- Belongings (@methodOf)
- Description
- Params
- Return
- Angular Specific Attribute
- @restrict
NG DOC
PARAMETER TYPES...
#6
Code Quality
Automate Code Quality Check
- Dependencies Status
- Duplicated Code
- Complex Function
- Error Handling
- Lint Status
- Test Coverage
BITHOUND.IO
Software insight as a
service
Free for OS project
BITHOUND.IO
BITHOUND.IO
KARMA COVERAGE
Karma Coverage Plugin
- Easy to set up
- Generate different format
Usage
#7
Continuous
Integration
Why?
- Automate the process
- Error reduction
- Generate reports
- 1 click (or no-click deploy)
Tools
Travis CI
Jenkins CI
Strider CD
Tools
#8
Development
Workflow
Git Flow
- Stable branch with released version
- Stable branch with new features
- Shared Standard
How dows it work...
GIT FLOW: https://www.atlassian.com/git/tutorials/comparing-
workflows/gitflow-workflow
Master
Develop
Feature Branch
Release Branch
HotFix Branch
Tools...
#9
Team
Communication
SLACK
- Issues
- Snippets
- Usefull Link
- Dependencies Docs
- Real Time Notification
Tools...
#10
Ask yourself..
If I leave tomorrow…
… and someone have to work on
this project …
Will I like
to be that guy?
Thanks!
@_teone
#angularconf15

More Related Content

What's hot (20)

PDF
Gettings started with the superheroic JavaScript library AngularJS
Armin Vieweg
 
PDF
Advanced Tips & Tricks for using Angular JS
Simon Guest
 
PDF
AngularJS Best Practices
Betclic Everest Group Tech Team
 
PDF
Introduction to AngularJS
Aldo Pizzagalli
 
PPTX
AngularJS - The Next Big Thing?
Tom Hombergs
 
PDF
AngularJS introduction
Tania Gonzales
 
PPTX
Why angular js Framework
Sakthi Bro
 
PPTX
AngularJS is awesome
Eusebiu Schipor
 
PPTX
Single Page Applications in SharePoint with Angular
Sparkhound Inc.
 
PDF
AngularJS
Hiten Pratap Singh
 
PDF
Introduction to AngularJS
Jussi Pohjolainen
 
PDF
AngularJS interview questions
Uri Lukach
 
PDF
Angularjs in mobile app
Yvonne Yu
 
PPTX
Introduction to Angularjs
Manish Shekhawat
 
PPTX
AngularJS - Architecture decisions in a large project 
Elad Hirsch
 
DOCX
Angular.js interview questions
codeandyou forums
 
PDF
Angular 2 overview
Jesse Warden
 
PPTX
Angular js
Dinusha Nandika
 
PPTX
AngularJS One Day Workshop
Shyam Seshadri
 
PPTX
Front end development with Angular JS
Bipin
 
Gettings started with the superheroic JavaScript library AngularJS
Armin Vieweg
 
Advanced Tips & Tricks for using Angular JS
Simon Guest
 
AngularJS Best Practices
Betclic Everest Group Tech Team
 
Introduction to AngularJS
Aldo Pizzagalli
 
AngularJS - The Next Big Thing?
Tom Hombergs
 
AngularJS introduction
Tania Gonzales
 
Why angular js Framework
Sakthi Bro
 
AngularJS is awesome
Eusebiu Schipor
 
Single Page Applications in SharePoint with Angular
Sparkhound Inc.
 
Introduction to AngularJS
Jussi Pohjolainen
 
AngularJS interview questions
Uri Lukach
 
Angularjs in mobile app
Yvonne Yu
 
Introduction to Angularjs
Manish Shekhawat
 
AngularJS - Architecture decisions in a large project 
Elad Hirsch
 
Angular.js interview questions
codeandyou forums
 
Angular 2 overview
Jesse Warden
 
Angular js
Dinusha Nandika
 
AngularJS One Day Workshop
Shyam Seshadri
 
Front end development with Angular JS
Bipin
 

Viewers also liked (20)

PPTX
Angular 2
Nigam Goyal
 
PDF
The Web Development Eco-system with VSTS, ASP.NET 2.0 & Microsoft Ajax
Darren Sim
 
ODP
Introduction to Angular 2
Knoldus Inc.
 
ODP
Consume RESTful APIs with $resource and Restangular
John Schmidt
 
PDF
Write bulletproof trigger code
Salesforce Developers
 
PDF
Angular2 with TypeScript
Rohit Bishnoi
 
PPTX
Git/Github & Salesforce
Gordon Bockus
 
PDF
최근 Javascript framework 조사
Kichul Jung
 
PDF
[143]Inside fuse deview 2016
NAVER D2
 
PPTX
Angular js
Behind D Walls
 
PPTX
AngularJS Animations
Eyal Vardi
 
PPTX
Live Demo : Trending Angular JS Featues
Edureka!
 
PDF
Building scalable applications with angular js
Andrew Alpert
 
PDF
Creating modern java web applications based on struts2 and angularjs
Johannes Geppert
 
PPTX
Building ColdFusion And AngularJS Applications
ColdFusionConference
 
PPTX
Multiorg Collaboration Using Salesforce S2S
Mayur Shintre
 
PPTX
Getting Started with Angular JS
Akshay Mathur
 
PDF
Angular JS - Develop Responsive Single Page Application
Edureka!
 
PDF
Mapping your content strategy
Hilary Marsh, Content Company, Inc.
 
PDF
Angular JS: First look เริ่มต้น Angular JS กันแบบสบายๆ
Teerasej Jiraphatchandej
 
Angular 2
Nigam Goyal
 
The Web Development Eco-system with VSTS, ASP.NET 2.0 & Microsoft Ajax
Darren Sim
 
Introduction to Angular 2
Knoldus Inc.
 
Consume RESTful APIs with $resource and Restangular
John Schmidt
 
Write bulletproof trigger code
Salesforce Developers
 
Angular2 with TypeScript
Rohit Bishnoi
 
Git/Github & Salesforce
Gordon Bockus
 
최근 Javascript framework 조사
Kichul Jung
 
[143]Inside fuse deview 2016
NAVER D2
 
Angular js
Behind D Walls
 
AngularJS Animations
Eyal Vardi
 
Live Demo : Trending Angular JS Featues
Edureka!
 
Building scalable applications with angular js
Andrew Alpert
 
Creating modern java web applications based on struts2 and angularjs
Johannes Geppert
 
Building ColdFusion And AngularJS Applications
ColdFusionConference
 
Multiorg Collaboration Using Salesforce S2S
Mayur Shintre
 
Getting Started with Angular JS
Akshay Mathur
 
Angular JS - Develop Responsive Single Page Application
Edureka!
 
Mapping your content strategy
Hilary Marsh, Content Company, Inc.
 
Angular JS: First look เริ่มต้น Angular JS กันแบบสบายๆ
Teerasej Jiraphatchandej
 
Ad

Similar to Angular js best practice (20)

PDF
"Different software evolutions from Start till Release in PHP product" Oleksa...
Fwdays
 
PDF
PHPFrameworkDay 2020 - Different software evolutions from Start till Release ...
Alexandr Savchenko
 
PDF
(ATS6-DEV02) Web Application Strategies
BIOVIA
 
PPTX
Software Development
Juan Victor Minaya León
 
PPTX
Latest trends in information technology
Eldos Kuriakose
 
PPTX
Developing .NET Core AWS Lambda functions
Deniz İrgin
 
PDF
introduction to micro services
Spyros Lambrinidis
 
PPTX
Angular js workshop
Rolands Krumbergs
 
PPTX
Modern Web-site Development Pipeline
GlobalLogic Ukraine
 
PDF
Code driven development in drupal
Andriy Yun
 
PPTX
ATAGTR2017 Protractor Cucumber BDD Approach
Agile Testing Alliance
 
PPTX
CucumberSeleniumWD
Vikas Sarin
 
PDF
Angular (v2 and up) - Morning to understand - Linagora
LINAGORA
 
PPT
CodeCharge Studio RAD tool
Stefan Prutianu
 
PPTX
ConFoo Montreal - Microservices for building an IDE - The innards of JetBrain...
Maarten Balliauw
 
PDF
Camunda BPM 7.2: Connectors, Data, Scripting (English)
camunda services GmbH
 
PPTX
Building Massive AngularJS Apps
Gordon Bockus
 
PPTX
Having fun with code igniter
Ahmad Arif
 
PDF
Up and Running with gRPC & Cloud Career [GDG-Cloud-Dhaka-IO/2022}
Md. Sadhan Sarker
 
PDF
Evolutionary Design Solid
Xebia IT Architects
 
"Different software evolutions from Start till Release in PHP product" Oleksa...
Fwdays
 
PHPFrameworkDay 2020 - Different software evolutions from Start till Release ...
Alexandr Savchenko
 
(ATS6-DEV02) Web Application Strategies
BIOVIA
 
Software Development
Juan Victor Minaya León
 
Latest trends in information technology
Eldos Kuriakose
 
Developing .NET Core AWS Lambda functions
Deniz İrgin
 
introduction to micro services
Spyros Lambrinidis
 
Angular js workshop
Rolands Krumbergs
 
Modern Web-site Development Pipeline
GlobalLogic Ukraine
 
Code driven development in drupal
Andriy Yun
 
ATAGTR2017 Protractor Cucumber BDD Approach
Agile Testing Alliance
 
CucumberSeleniumWD
Vikas Sarin
 
Angular (v2 and up) - Morning to understand - Linagora
LINAGORA
 
CodeCharge Studio RAD tool
Stefan Prutianu
 
ConFoo Montreal - Microservices for building an IDE - The innards of JetBrain...
Maarten Balliauw
 
Camunda BPM 7.2: Connectors, Data, Scripting (English)
camunda services GmbH
 
Building Massive AngularJS Apps
Gordon Bockus
 
Having fun with code igniter
Ahmad Arif
 
Up and Running with gRPC & Cloud Career [GDG-Cloud-Dhaka-IO/2022}
Md. Sadhan Sarker
 
Evolutionary Design Solid
Xebia IT Architects
 
Ad

Recently uploaded (16)

PPTX
presentation on legal and regulatory action
raoharsh4122001
 
PDF
The Family Secret (essence of loveliness)
Favour Biodun
 
PPTX
Presentationexpressions You are student leader and have just come from a stud...
BENSTARBEATZ
 
PPTX
Great-Books. Powerpoint presentation. files
tamayocrisgie
 
PPTX
BARRIERS TO EFFECTIVE COMMUNICATION.pptx
shraddham25
 
PPTX
some leadership theories MBA management.pptx
rkseo19
 
PPTX
Inspired by VeinSense: Supercharge Your Hackathon with Agentic AI
ShubhamSharma2528
 
PPTX
STURGEON BAY WI AG PPT JULY 6 2025.pptx
FamilyWorshipCenterD
 
PDF
The Impact of Game Live Streaming on In-Game Purchases of Chinese Young Game ...
Shibaura Institute of Technology
 
PDF
Cloud Computing Service Availability.pdf
chakrirocky1
 
PPTX
Pastor Bob Stewart Acts 21 07 09 2025.pptx
FamilyWorshipCenterD
 
PDF
Generalization predition MOOCs - Conference presentation - eMOOCs 2025
pmmorenom01
 
PPTX
AI presentation for everyone in every fields
dodinhkhai1
 
PDF
Leveraging the Power of Jira Dashboard.pdf
siddharthshukla742740
 
PPTX
Food_and_Drink_Bahasa_Inggris_Kelas_5.pptx
debbystevani36
 
PPTX
2025-07-06 Abraham 06 (shared slides).pptx
Dale Wells
 
presentation on legal and regulatory action
raoharsh4122001
 
The Family Secret (essence of loveliness)
Favour Biodun
 
Presentationexpressions You are student leader and have just come from a stud...
BENSTARBEATZ
 
Great-Books. Powerpoint presentation. files
tamayocrisgie
 
BARRIERS TO EFFECTIVE COMMUNICATION.pptx
shraddham25
 
some leadership theories MBA management.pptx
rkseo19
 
Inspired by VeinSense: Supercharge Your Hackathon with Agentic AI
ShubhamSharma2528
 
STURGEON BAY WI AG PPT JULY 6 2025.pptx
FamilyWorshipCenterD
 
The Impact of Game Live Streaming on In-Game Purchases of Chinese Young Game ...
Shibaura Institute of Technology
 
Cloud Computing Service Availability.pdf
chakrirocky1
 
Pastor Bob Stewart Acts 21 07 09 2025.pptx
FamilyWorshipCenterD
 
Generalization predition MOOCs - Conference presentation - eMOOCs 2025
pmmorenom01
 
AI presentation for everyone in every fields
dodinhkhai1
 
Leveraging the Power of Jira Dashboard.pdf
siddharthshukla742740
 
Food_and_Drink_Bahasa_Inggris_Kelas_5.pptx
debbystevani36
 
2025-07-06 Abraham 06 (shared slides).pptx
Dale Wells
 

Angular js best practice