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

PPTX
Introduction to Angular js 2.0
PDF
AngularJS performance & production tips
PDF
Angular Best Practices v2
PDF
AngularJS best-practices
PDF
AngularJS - What is it & Why is it awesome ? (with demos)
PPTX
Angular js tutorial slides
PDF
AngularJS application architecture
PPTX
Angular js architecture (v1.4.8)
Introduction to Angular js 2.0
AngularJS performance & production tips
Angular Best Practices v2
AngularJS best-practices
AngularJS - What is it & Why is it awesome ? (with demos)
Angular js tutorial slides
AngularJS application architecture
Angular js architecture (v1.4.8)

What's hot (20)

PDF
Gettings started with the superheroic JavaScript library AngularJS
PDF
Advanced Tips & Tricks for using Angular JS
PDF
AngularJS Best Practices
PDF
Introduction to AngularJS
PPTX
AngularJS - The Next Big Thing?
PDF
AngularJS introduction
PPTX
Why angular js Framework
PPTX
AngularJS is awesome
PPTX
Single Page Applications in SharePoint with Angular
PDF
PDF
Introduction to AngularJS
PDF
AngularJS interview questions
PDF
Angularjs in mobile app
PPTX
Introduction to Angularjs
PPTX
AngularJS - Architecture decisions in a large project 
DOCX
Angular.js interview questions
PDF
Angular 2 overview
PPTX
Angular js
PPTX
AngularJS One Day Workshop
PPTX
Front end development with Angular JS
Gettings started with the superheroic JavaScript library AngularJS
Advanced Tips & Tricks for using Angular JS
AngularJS Best Practices
Introduction to AngularJS
AngularJS - The Next Big Thing?
AngularJS introduction
Why angular js Framework
AngularJS is awesome
Single Page Applications in SharePoint with Angular
Introduction to AngularJS
AngularJS interview questions
Angularjs in mobile app
Introduction to Angularjs
AngularJS - Architecture decisions in a large project 
Angular.js interview questions
Angular 2 overview
Angular js
AngularJS One Day Workshop
Front end development with Angular JS
Ad

Viewers also liked (20)

PPTX
Angular 2
PDF
The Web Development Eco-system with VSTS, ASP.NET 2.0 & Microsoft Ajax
ODP
Introduction to Angular 2
ODP
Consume RESTful APIs with $resource and Restangular
PDF
Write bulletproof trigger code
PDF
Angular2 with TypeScript
PPTX
Git/Github & Salesforce
PDF
최근 Javascript framework 조사
PDF
[143]Inside fuse deview 2016
PPTX
Angular js
PPTX
AngularJS Animations
PPTX
Live Demo : Trending Angular JS Featues
PDF
Building scalable applications with angular js
PDF
Creating modern java web applications based on struts2 and angularjs
PPTX
Building ColdFusion And AngularJS Applications
PPTX
Multiorg Collaboration Using Salesforce S2S
PPTX
Getting Started with Angular JS
PDF
Angular JS - Develop Responsive Single Page Application
PDF
Mapping your content strategy
PDF
Angular JS: First look เริ่มต้น Angular JS กันแบบสบายๆ
Angular 2
The Web Development Eco-system with VSTS, ASP.NET 2.0 & Microsoft Ajax
Introduction to Angular 2
Consume RESTful APIs with $resource and Restangular
Write bulletproof trigger code
Angular2 with TypeScript
Git/Github & Salesforce
최근 Javascript framework 조사
[143]Inside fuse deview 2016
Angular js
AngularJS Animations
Live Demo : Trending Angular JS Featues
Building scalable applications with angular js
Creating modern java web applications based on struts2 and angularjs
Building ColdFusion And AngularJS Applications
Multiorg Collaboration Using Salesforce S2S
Getting Started with Angular JS
Angular JS - Develop Responsive Single Page Application
Mapping your content strategy
Angular JS: First look เริ่มต้น Angular JS กันแบบสบายๆ
Ad

Similar to Angular js best practice (20)

PPTX
Angular Best Practices To Build Clean and Performant Web Applications
PDF
Angular (v2 and up) - Morning to understand - Linagora
PDF
I - Front-end Spectrum
PDF
Angular Architecture Best Practices.pdf
PDF
Building Enterprise Grade Front-End Applications with JavaScript Frameworks
PDF
Industry-Standard Web Development Techniques for Angular
PDF
Real World AngularJS recipes: beyond TodoMVC - Carlo Bonamico, Sonia Pini - C...
PDF
Real World AngularJS recipes: beyond TodoMVC
PDF
Why Angular It's Still a Top Choice for Developers in 2025.pdf
PDF
AngularJS in Production (CTO Forum)
PDF
How Angular Development services can help you in expanding your business?.pdf
PDF
Angular Web App Development
PPTX
Why Should You Consider Angular.js for Web App Development? Detail Guide
DOCX
DOCX
DOCX
DOCX
DOCX
angular content
PPTX
7 Key Reasons To Choose Angular for Mobile App Development Project
PPTX
Writing a massive javascript app
Angular Best Practices To Build Clean and Performant Web Applications
Angular (v2 and up) - Morning to understand - Linagora
I - Front-end Spectrum
Angular Architecture Best Practices.pdf
Building Enterprise Grade Front-End Applications with JavaScript Frameworks
Industry-Standard Web Development Techniques for Angular
Real World AngularJS recipes: beyond TodoMVC - Carlo Bonamico, Sonia Pini - C...
Real World AngularJS recipes: beyond TodoMVC
Why Angular It's Still a Top Choice for Developers in 2025.pdf
AngularJS in Production (CTO Forum)
How Angular Development services can help you in expanding your business?.pdf
Angular Web App Development
Why Should You Consider Angular.js for Web App Development? Detail Guide
angular content
7 Key Reasons To Choose Angular for Mobile App Development Project
Writing a massive javascript app

Recently uploaded (20)

PPTX
What is Clause, definition and structure
PPTX
Cohort Study_PPT.group presentation_pdf.pptx
PPTX
Postmodernism notes for literature students
PPTX
2025-08-03 Joseph 01 (shared slides).pptx
PPTX
Non-Verbal-Communication .mh.pdf_110245_compressed.pptx
PPTX
Role and Responsibilities of Bangladesh Coast Guard Base, Mongla Challenges
PPTX
Bob Stewart Journey to Rome 07 30 2025.pptx
PPTX
business communication final draftt.pptx
PPT
strucure of protein geomics for new .ppt
PPTX
Information Security and Risk Management.pptx
PDF
protein structure and function for basics .pdf
PPTX
Presentation of Project of Enterprenuership topic- "Green Gaurdian"
PDF
Enhancing Bambara Groundnut Production Through Improved Agronomic Practices
PPTX
DARKWEB Deepweb what to do or not ?.pptx
PPTX
CASE PRESENTATION prev 1 lscs[1].pptxgyjgg
PPTX
Caption Text about Social Media Post in Internet
PPTX
Emphasizing It's Not The End 08 06 2025.pptx
PPTX
Understanding-Communication-Berlos-S-M-C-R-Model.pptx
PPTX
Selecting relevant value chain/s for Impactful Development Policies
PPTX
IBA DISTRICT PIR PRESENTATION.POWERPOINT
What is Clause, definition and structure
Cohort Study_PPT.group presentation_pdf.pptx
Postmodernism notes for literature students
2025-08-03 Joseph 01 (shared slides).pptx
Non-Verbal-Communication .mh.pdf_110245_compressed.pptx
Role and Responsibilities of Bangladesh Coast Guard Base, Mongla Challenges
Bob Stewart Journey to Rome 07 30 2025.pptx
business communication final draftt.pptx
strucure of protein geomics for new .ppt
Information Security and Risk Management.pptx
protein structure and function for basics .pdf
Presentation of Project of Enterprenuership topic- "Green Gaurdian"
Enhancing Bambara Groundnut Production Through Improved Agronomic Practices
DARKWEB Deepweb what to do or not ?.pptx
CASE PRESENTATION prev 1 lscs[1].pptxgyjgg
Caption Text about Social Media Post in Internet
Emphasizing It's Not The End 08 06 2025.pptx
Understanding-Communication-Berlos-S-M-C-R-Model.pptx
Selecting relevant value chain/s for Impactful Development Policies
IBA DISTRICT PIR PRESENTATION.POWERPOINT

Angular js best practice