SlideShare a Scribd company logo
1 of 36
HTML Enhanced For Web App!
hallenge
hallenge
WHAT
WHY HOW
hallenge
AngularJs là gì ?
What???
hallenge
“ Dự án AngularJS được bắt đầu từ năm 2009, do lập
trình viên Misko Hevery tại Google viết ra như là một
dự án kiểu “viết cho vui”. Misko và nhóm lúc này đang
tham gia vào 1 dự án của Google tên là Google
Feedback.Với AngularJS, Misko đã rút ngắn số dòng
code front-end từ 17000 dòng còn chỉ khoảng 1500.Với
sự thành công đó, đội ngũ của dự án Google Feedback
quyết định phát triển AngularJS theo hướng mã nguồn
mở.”
hallenge
AngularJS là một bộ Javascript
Framework rất mạnh và
thường được sử dụng để xây
dựng project Single Page
Application (SPA). AngularJS
cho phép xây dựng ngay trong
trình duyệt mà không cần phải
thông qua server, sử dụng mô
hình MVC.
hallenge
hallenge
Mô hình MVC
 Model - Là thành phần
thấp nhất của mô hình
có nhiệm vụ duy trì dữ
liệu.
 View - Có nhiệm vụ
hiển thị các phần dữ
liệu đến người sử
dụng.
 Controller - Là phần
Code điều khiển sự
tương tác giữa Model
và View
hallenge
Mô hình MVC trong AngulaJS
hallenge
Tại sao chúng ta nên sử
dụng AngularJS ?
Why???
hallenge
 AngularJS được phát triển bởi Google và là mã nguồn mở
viết theo mô hình MVC.
 AngularJS cho phép tạo ra các ứng dụng một cách đơn
giản, code sạch, dễ dàng hơn trong việc kiểm thử.
hallenge
 Tương thích với hầu hết các trình duyệt trên các điện thoại
thông minh (iOS, Android).
 AngularJS sử dụng cơ chế data-binding tức là khi model thay
đổi thì view cũng thay đổi theo và ngược lại.
 Được tích cực phát triển bởi cộng đồng mã nguồn mở
(on GitHub).
hallenge
 Extendable: khả năng mở rộng, có nghĩa là có thể
dễ dàng thêm những features mới cho người dùng.
 Maintainable: ứng dụng viết bằng angularJS rất dễ
debug và fix, điều này có ý nghĩa khi làm việc với
một project lớn.
hallenge
 Testable: AngularJS hỗ trợ unit, end-to-end testing, điều
đó thuận lợi cho việc fix và debug trước khi đến tay người
dùng.
 Standardized: angularJS được xây dựng dựa trên khả
năng sẵn có của trình duyệt nên cho phép tận dụng đặt
tính mới nhất ( như HTML API…) và cá công cụ phổ biến
khác.
hallenge
hallenge
hallenge
Sử dụng AngularJS như
thế nào ?
How???
hallenge
Sử dụng AngularJS
Phiên bản mới nhất của Angular hiện nay là 2.0.0-beta.15.
<script type="text/javascript"
src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/2.0.0-
beta.15/Rx.min.js"></script>
Link download: https://angularjs.org/
<script type="text/javascript" src=" path to angular
file"></script>
hallenge
hallenge
AngularJS Expression
• AngularJS expression có
thể được viết trong dấu
ngoặc kép:
{{expression}}.
• AngularJS sẽ giải quyết
các expression, và trả về
kết quả chính xác nơi
biểu thức được viết.
hallenge
Data Binding trong AngularJs
là cách thức tự động đồng bộ
(synchronization) dữ liệu giữa
Model vàView.
Data Bingding
hallenge
hallenge
 AngularJS có một tập hợp
các chỉ thị xây dựng sẵn,
trong đó cung cấp các
chức năng cho các ứng
dụng gọi là directives.
 Có thể tự định nghĩa một
directive.
 Cú pháp: ng-something
hallenge
 AngularJS Module được
định nghĩa như một
application.
 Modules là 1 bộ phận chứa
các controllers cho ứng
dụng.
 AngularJS Controller kiểm
soát dữ liệu của các ứng
dụng AngularJS.
 Controller được chứa trong
module.
Module and Controller
hallenge
 Phạm vi là một phần ràng
buộc giữa HTML (View) và
JavaScript (Controller).
 Scope chứa thông tin là
các dữ liệu model.
 Trong controller, dữ liệu
model có thể được truy
cập qua đối tượng $scope.
Scope
hallenge
Module
Controller
Scope
Directives
hallenge
AngularJS Services
 Service là các hàm
JavaScript và có nhiệm
vụ trên những task nhất
định. Nó làm cho chúng
thành những thực thể
riêng rẽ dễ dàng trong
việc bảo trì và kiểm thử.
Controller có thể gọi
chúng một cách đơn
giản
hallenge
hallenge
AngularJs Filter
AngularJs cung cấp các Filter(bộ lọc) để chuyển đổi dữ liệu
hallenge
Dependency Injection
 Dependency Injection là kỹ thuật
nổi bật của AngularJS, nó là
design pattern.
 Điều này làm cho cách thành phần
phụ thuộc nhau trong phần cấu
hình.
 Kỹ thuật này giúp tái sử dụng
thành phần, bảo trì và kiểm thử.
hallenge
Dependency Injection
hallenge
AngularJS BackboneJS EmberJS
Template
Filter
Data binding
Routing
API
Model
Controller
Event Handles
Animation
SQL
Service
hallenge
W3C School:
http://www.w3schools.com/angular/default.asp
AngularJS.Org:
https://docs.angularjs.org/tutorial
TutorialPoint:
http://www.tutorialspoint.com//angularjs/index.htm
Tài liệu tham khảo
hallenge
DEMO
hallenge
Q&A
hallenge
Thank You!

More Related Content

What's hot

Angular 6 - The Complete Guide
Angular 6 - The Complete GuideAngular 6 - The Complete Guide
Angular 6 - The Complete GuideSam Dias
 
Kiến trúc-hướng-dịch-vụ-webservice
Kiến trúc-hướng-dịch-vụ-webserviceKiến trúc-hướng-dịch-vụ-webservice
Kiến trúc-hướng-dịch-vụ-webserviceThuyet Nguyen
 
Single Page Application (SPA) using AngularJS
Single Page Application (SPA) using AngularJSSingle Page Application (SPA) using AngularJS
Single Page Application (SPA) using AngularJSM R Rony
 
Angular kickstart slideshare
Angular kickstart   slideshareAngular kickstart   slideshare
Angular kickstart slideshareSaleemMalik52
 
Bảo trì phần mềm
Bảo trì phần mềmBảo trì phần mềm
Bảo trì phần mềmNguyễn Anh
 
Slide Báo Cáo Đồ Án Tốt Nghiệp CNTT
Slide Báo Cáo Đồ Án Tốt Nghiệp CNTTSlide Báo Cáo Đồ Án Tốt Nghiệp CNTT
Slide Báo Cáo Đồ Án Tốt Nghiệp CNTTHiệu Nguyễn
 
Angular 5 presentation for beginners
Angular 5 presentation for beginnersAngular 5 presentation for beginners
Angular 5 presentation for beginnersImran Qasim
 
Phần 2: Giới thiệu ngôn ngữ lập trình C
Phần 2: Giới thiệu ngôn ngữ lập trình CPhần 2: Giới thiệu ngôn ngữ lập trình C
Phần 2: Giới thiệu ngôn ngữ lập trình CHuy Rùa
 
Slide báo cáo đồ án tốt nghiệp "Website cửa hàng điện thoại trực tuyến"
Slide báo cáo đồ án tốt nghiệp "Website cửa hàng điện thoại trực tuyến"Slide báo cáo đồ án tốt nghiệp "Website cửa hàng điện thoại trực tuyến"
Slide báo cáo đồ án tốt nghiệp "Website cửa hàng điện thoại trực tuyến"Tú Cao
 
Spring framework
Spring frameworkSpring framework
Spring frameworkAn Nguyen
 
Phân tích và thiết kế hệ thống quản lý bán hàng
Phân tích và thiết kế hệ thống quản lý bán hàngPhân tích và thiết kế hệ thống quản lý bán hàng
Phân tích và thiết kế hệ thống quản lý bán hàngleemindinh
 
Do an xay_dung_website_thuong_mai_dien_tu
Do an xay_dung_website_thuong_mai_dien_tuDo an xay_dung_website_thuong_mai_dien_tu
Do an xay_dung_website_thuong_mai_dien_tuThiênĐàng CôngDân
 
Ứng dụng công cụ test tự động kiểm thử website
Ứng dụng công cụ test tự động kiểm thử websiteỨng dụng công cụ test tự động kiểm thử website
Ứng dụng công cụ test tự động kiểm thử websiteDotnet Open Group
 
Unit 1 - TypeScript & Introduction to Angular CLI.pptx
Unit 1 - TypeScript & Introduction to Angular CLI.pptxUnit 1 - TypeScript & Introduction to Angular CLI.pptx
Unit 1 - TypeScript & Introduction to Angular CLI.pptxMalla Reddy University
 

What's hot (20)

AngularJS
AngularJS AngularJS
AngularJS
 
Angular 6 - The Complete Guide
Angular 6 - The Complete GuideAngular 6 - The Complete Guide
Angular 6 - The Complete Guide
 
Kiến trúc-hướng-dịch-vụ-webservice
Kiến trúc-hướng-dịch-vụ-webserviceKiến trúc-hướng-dịch-vụ-webservice
Kiến trúc-hướng-dịch-vụ-webservice
 
Angular
AngularAngular
Angular
 
Single Page Application (SPA) using AngularJS
Single Page Application (SPA) using AngularJSSingle Page Application (SPA) using AngularJS
Single Page Application (SPA) using AngularJS
 
Angular
AngularAngular
Angular
 
Angular
AngularAngular
Angular
 
Angular kickstart slideshare
Angular kickstart   slideshareAngular kickstart   slideshare
Angular kickstart slideshare
 
Bảo trì phần mềm
Bảo trì phần mềmBảo trì phần mềm
Bảo trì phần mềm
 
Slide Báo Cáo Đồ Án Tốt Nghiệp CNTT
Slide Báo Cáo Đồ Án Tốt Nghiệp CNTTSlide Báo Cáo Đồ Án Tốt Nghiệp CNTT
Slide Báo Cáo Đồ Án Tốt Nghiệp CNTT
 
Angular 5 presentation for beginners
Angular 5 presentation for beginnersAngular 5 presentation for beginners
Angular 5 presentation for beginners
 
Phần 2: Giới thiệu ngôn ngữ lập trình C
Phần 2: Giới thiệu ngôn ngữ lập trình CPhần 2: Giới thiệu ngôn ngữ lập trình C
Phần 2: Giới thiệu ngôn ngữ lập trình C
 
Slide báo cáo đồ án tốt nghiệp "Website cửa hàng điện thoại trực tuyến"
Slide báo cáo đồ án tốt nghiệp "Website cửa hàng điện thoại trực tuyến"Slide báo cáo đồ án tốt nghiệp "Website cửa hàng điện thoại trực tuyến"
Slide báo cáo đồ án tốt nghiệp "Website cửa hàng điện thoại trực tuyến"
 
Spring framework
Spring frameworkSpring framework
Spring framework
 
Introduction to Angularjs
Introduction to AngularjsIntroduction to Angularjs
Introduction to Angularjs
 
Phân tích và thiết kế hệ thống quản lý bán hàng
Phân tích và thiết kế hệ thống quản lý bán hàngPhân tích và thiết kế hệ thống quản lý bán hàng
Phân tích và thiết kế hệ thống quản lý bán hàng
 
Do an xay_dung_website_thuong_mai_dien_tu
Do an xay_dung_website_thuong_mai_dien_tuDo an xay_dung_website_thuong_mai_dien_tu
Do an xay_dung_website_thuong_mai_dien_tu
 
Node.js căn bản
Node.js căn bảnNode.js căn bản
Node.js căn bản
 
Ứng dụng công cụ test tự động kiểm thử website
Ứng dụng công cụ test tự động kiểm thử websiteỨng dụng công cụ test tự động kiểm thử website
Ứng dụng công cụ test tự động kiểm thử website
 
Unit 1 - TypeScript & Introduction to Angular CLI.pptx
Unit 1 - TypeScript & Introduction to Angular CLI.pptxUnit 1 - TypeScript & Introduction to Angular CLI.pptx
Unit 1 - TypeScript & Introduction to Angular CLI.pptx
 

Similar to Angular js

Asp.net mvc framework qua cac vi du
Asp.net mvc framework  qua cac vi duAsp.net mvc framework  qua cac vi du
Asp.net mvc framework qua cac vi duKim Hyun Hai
 
Báo cáo thực tập chuyên nghành lập trình Android GPSGroup
Báo cáo thực tập chuyên nghành lập trình Android GPSGroupBáo cáo thực tập chuyên nghành lập trình Android GPSGroup
Báo cáo thực tập chuyên nghành lập trình Android GPSGroupTinh Ngo
 
429157477-Slide-Bao-Cao.pdf
429157477-Slide-Bao-Cao.pdf429157477-Slide-Bao-Cao.pdf
429157477-Slide-Bao-Cao.pdfToNguyen16
 
Tổng quan về struts framework, mvc
Tổng quan về struts framework, mvc  Tổng quan về struts framework, mvc
Tổng quan về struts framework, mvc truong nguyen
 
Giới thiệu Overview về AngularJS, Yeoman
Giới thiệu Overview về AngularJS, YeomanGiới thiệu Overview về AngularJS, Yeoman
Giới thiệu Overview về AngularJS, YeomanQSoft Vietnam
 
Mô hình MVC trong lập trình web với Java
Mô hình MVC trong lập trình web với JavaMô hình MVC trong lập trình web với Java
Mô hình MVC trong lập trình web với JavaHuy Vũ
 
Jdeveloper12c
Jdeveloper12cJdeveloper12c
Jdeveloper12cle larry
 
Asp.net mvc 3 (c#) (9 tutorials) egroups vn
Asp.net mvc 3 (c#) (9 tutorials)   egroups vnAsp.net mvc 3 (c#) (9 tutorials)   egroups vn
Asp.net mvc 3 (c#) (9 tutorials) egroups vnNguyen Van Hung
 
Bao cao wesite bán giày.docx
Bao cao wesite bán giày.docxBao cao wesite bán giày.docx
Bao cao wesite bán giày.docxssuser11005a
 
Spring mvc
Spring mvcSpring mvc
Spring mvcBa Big
 
Mô hình mvc trong ASP
Mô hình mvc trong ASPMô hình mvc trong ASP
Mô hình mvc trong ASPHannie Mia
 

Similar to Angular js (20)

Asp.net mvc framework qua cac vi du
Asp.net mvc framework  qua cac vi duAsp.net mvc framework  qua cac vi du
Asp.net mvc framework qua cac vi du
 
Báo cáo thực tập chuyên nghành lập trình Android GPSGroup
Báo cáo thực tập chuyên nghành lập trình Android GPSGroupBáo cáo thực tập chuyên nghành lập trình Android GPSGroup
Báo cáo thực tập chuyên nghành lập trình Android GPSGroup
 
429157477-Slide-Bao-Cao.pdf
429157477-Slide-Bao-Cao.pdf429157477-Slide-Bao-Cao.pdf
429157477-Slide-Bao-Cao.pdf
 
Giao Trinh Jquery
Giao Trinh JqueryGiao Trinh Jquery
Giao Trinh Jquery
 
jquery.pdf
jquery.pdfjquery.pdf
jquery.pdf
 
J query
J queryJ query
J query
 
Tổng quan về struts framework, mvc
Tổng quan về struts framework, mvc  Tổng quan về struts framework, mvc
Tổng quan về struts framework, mvc
 
Giới thiệu Overview về AngularJS, Yeoman
Giới thiệu Overview về AngularJS, YeomanGiới thiệu Overview về AngularJS, Yeoman
Giới thiệu Overview về AngularJS, Yeoman
 
Mô hình MVC trong lập trình web với Java
Mô hình MVC trong lập trình web với JavaMô hình MVC trong lập trình web với Java
Mô hình MVC trong lập trình web với Java
 
Jdeveloper12c
Jdeveloper12cJdeveloper12c
Jdeveloper12c
 
5.spring.net
5.spring.net5.spring.net
5.spring.net
 
Mvc 3
Mvc 3Mvc 3
Mvc 3
 
Asp.net mvc 3 (c#) (9 tutorials) egroups vn
Asp.net mvc 3 (c#) (9 tutorials)   egroups vnAsp.net mvc 3 (c#) (9 tutorials)   egroups vn
Asp.net mvc 3 (c#) (9 tutorials) egroups vn
 
Slide t smar
Slide t smarSlide t smar
Slide t smar
 
Bao cao wesite bán giày.docx
Bao cao wesite bán giày.docxBao cao wesite bán giày.docx
Bao cao wesite bán giày.docx
 
Aspnet 3.5_03
Aspnet 3.5_03Aspnet 3.5_03
Aspnet 3.5_03
 
Spring mvc
Spring mvcSpring mvc
Spring mvc
 
Thuyet trinh java fx
Thuyet trinh java fxThuyet trinh java fx
Thuyet trinh java fx
 
Java fx
Java fxJava fx
Java fx
 
Mô hình mvc trong ASP
Mô hình mvc trong ASPMô hình mvc trong ASP
Mô hình mvc trong ASP
 

Angular js

  • 1. HTML Enhanced For Web App!
  • 5. hallenge “ Dự án AngularJS được bắt đầu từ năm 2009, do lập trình viên Misko Hevery tại Google viết ra như là một dự án kiểu “viết cho vui”. Misko và nhóm lúc này đang tham gia vào 1 dự án của Google tên là Google Feedback.Với AngularJS, Misko đã rút ngắn số dòng code front-end từ 17000 dòng còn chỉ khoảng 1500.Với sự thành công đó, đội ngũ của dự án Google Feedback quyết định phát triển AngularJS theo hướng mã nguồn mở.”
  • 6. hallenge AngularJS là một bộ Javascript Framework rất mạnh và thường được sử dụng để xây dựng project Single Page Application (SPA). AngularJS cho phép xây dựng ngay trong trình duyệt mà không cần phải thông qua server, sử dụng mô hình MVC.
  • 8. hallenge Mô hình MVC  Model - Là thành phần thấp nhất của mô hình có nhiệm vụ duy trì dữ liệu.  View - Có nhiệm vụ hiển thị các phần dữ liệu đến người sử dụng.  Controller - Là phần Code điều khiển sự tương tác giữa Model và View
  • 9. hallenge Mô hình MVC trong AngulaJS
  • 10. hallenge Tại sao chúng ta nên sử dụng AngularJS ? Why???
  • 11. hallenge  AngularJS được phát triển bởi Google và là mã nguồn mở viết theo mô hình MVC.  AngularJS cho phép tạo ra các ứng dụng một cách đơn giản, code sạch, dễ dàng hơn trong việc kiểm thử.
  • 12. hallenge  Tương thích với hầu hết các trình duyệt trên các điện thoại thông minh (iOS, Android).  AngularJS sử dụng cơ chế data-binding tức là khi model thay đổi thì view cũng thay đổi theo và ngược lại.  Được tích cực phát triển bởi cộng đồng mã nguồn mở (on GitHub).
  • 13. hallenge  Extendable: khả năng mở rộng, có nghĩa là có thể dễ dàng thêm những features mới cho người dùng.  Maintainable: ứng dụng viết bằng angularJS rất dễ debug và fix, điều này có ý nghĩa khi làm việc với một project lớn.
  • 14. hallenge  Testable: AngularJS hỗ trợ unit, end-to-end testing, điều đó thuận lợi cho việc fix và debug trước khi đến tay người dùng.  Standardized: angularJS được xây dựng dựa trên khả năng sẵn có của trình duyệt nên cho phép tận dụng đặt tính mới nhất ( như HTML API…) và cá công cụ phổ biến khác.
  • 17. hallenge Sử dụng AngularJS như thế nào ? How???
  • 18. hallenge Sử dụng AngularJS Phiên bản mới nhất của Angular hiện nay là 2.0.0-beta.15. <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/2.0.0- beta.15/Rx.min.js"></script> Link download: https://angularjs.org/ <script type="text/javascript" src=" path to angular file"></script>
  • 20. hallenge AngularJS Expression • AngularJS expression có thể được viết trong dấu ngoặc kép: {{expression}}. • AngularJS sẽ giải quyết các expression, và trả về kết quả chính xác nơi biểu thức được viết.
  • 21. hallenge Data Binding trong AngularJs là cách thức tự động đồng bộ (synchronization) dữ liệu giữa Model vàView. Data Bingding
  • 23. hallenge  AngularJS có một tập hợp các chỉ thị xây dựng sẵn, trong đó cung cấp các chức năng cho các ứng dụng gọi là directives.  Có thể tự định nghĩa một directive.  Cú pháp: ng-something
  • 24. hallenge  AngularJS Module được định nghĩa như một application.  Modules là 1 bộ phận chứa các controllers cho ứng dụng.  AngularJS Controller kiểm soát dữ liệu của các ứng dụng AngularJS.  Controller được chứa trong module. Module and Controller
  • 25. hallenge  Phạm vi là một phần ràng buộc giữa HTML (View) và JavaScript (Controller).  Scope chứa thông tin là các dữ liệu model.  Trong controller, dữ liệu model có thể được truy cập qua đối tượng $scope. Scope
  • 27. hallenge AngularJS Services  Service là các hàm JavaScript và có nhiệm vụ trên những task nhất định. Nó làm cho chúng thành những thực thể riêng rẽ dễ dàng trong việc bảo trì và kiểm thử. Controller có thể gọi chúng một cách đơn giản
  • 29. hallenge AngularJs Filter AngularJs cung cấp các Filter(bộ lọc) để chuyển đổi dữ liệu
  • 30. hallenge Dependency Injection  Dependency Injection là kỹ thuật nổi bật của AngularJS, nó là design pattern.  Điều này làm cho cách thành phần phụ thuộc nhau trong phần cấu hình.  Kỹ thuật này giúp tái sử dụng thành phần, bảo trì và kiểm thử.
  • 32. hallenge AngularJS BackboneJS EmberJS Template Filter Data binding Routing API Model Controller Event Handles Animation SQL Service