Sunday, May 19, 2013

Các quy tắc cơ bản của HTML5, Phần 1: Bắt đầu


HTML5 là một ngôn ngữ được thiết kế để thiết lập nội dung web. Nó nhằm làm cho việc thiết kế và phát triển web dễ dàng hơn bằng cách tạo một giao diện ngôn ngữ đánh dấu chuẩn hóa và trực quan. HTML5 cung cấp các phương tiện phân tích và phân định các trang của bạn, và nó cho phép bạn tạo các thành phần rời rạc không chỉ được thiết kế để cấu tạo trang web một cách hợp lý mà còn được tạo ra để cung cấp cho trang web các khả năng thông tin. HTML5 có thể được gọi là "cách tiếp cận thông tin thông qua thiết kế" do nó kết hợp yếu tố cơ bản về lập bản đồ thông tin, phân chia và ghi nhãn thông tin giúp dễ dàng sử dụng và hiểu thông tin. Đây là nền tảng của tiện ích ngữ nghĩa và thẩm mỹ gây ấn tượng sâu sắc của HTML5. HTML5 cung cấp khả năng xuất bản tất cả mọi thứ trên thế giới từ nội dung văn bản đơn giản đến đa phương tiện phong phú, tương tác cho các nhà thiết kế và các nhà phát triển ở mọi trình độ.

Các từ viết tắt thông dụng

  • API: Application programming interface - Giao diện lập trình ứng dụng
  • CSS3: Cascading style sheet version 3 - Bảng định kiểu xếp chồng phiên bản 3
  • GUI: Graphical user interface - Giao diện người dùng đồ họa
  • HTML: Hypertext Markup Language - Ngôn ngữ đánh dấu siêu văn bản
  • HTML5: HTML phiên bản 5
  • SQL: Structured Query Language - Ngôn ngữ truy vấn có cấu trúc
  • UI: User interface - Giao diện người dùng
HTML5 cung cấp các công cụ quản lý dữ liệu, đồ họa, video, và âm thanh có hiệu quả. Nó tạo điều kiện cho sự phát triển của các ứng dụng giữa các trình duyệt với nhau cho trang web cũng như cho các thiết bị di động. HTML5 là một trong những công nghệ thúc đẩy những cải tiến trong các dịch vụ điện toán đám mây di động, vì nó tính đến tính linh hoạt rộng hơn, cho phép phát triển các trang web thú vị và có khả năng tương tác. Nó cũng đưa vào thẻ và các cải tiến mới, bao gồm cấu trúc thu nhỏ, các nút điều khiển của biểu mẫu, các API, đa phương tiện, hỗ trợ cơ sở dữ liệu, và tốc độ xử lý nhanh hơn đáng kể.
Các thẻ mới trong HTML5 có tính hấp dẫn cao, bao gồm cả vai trò và cách sử dụng của chúng. Các phiên bản trước của HTML thường dùng các thẻ không có gì nổi bật cả. Tuy nhiên, HTML5 có các nhãn trực quan, có khả năng mô tả cao. Nó cung cấp các nhãn nội dung phong phú ngay lập tức xác định nội dung. Ví dụ, thẻ 
 đã được bổ sung bằng các thẻ 
 và 
. Ngoài ra các thẻ, và 
 cũng đưa ra sự mô tả chính xác hơn về các kiểu nội dung cụ thể.

Phát triển kỹ năng về chủ đề này

Nội dung này nằm trong "đường dẫn đến kiến thức (knowledge path)" để bổ sung các kỹ năng của bạn. Xem Quy tắc cơ bản của HTML5.
HTML5 cung cấp:
  • Các thẻ mô tả chính xác những gì chúng được thiết kế để chứa đựng.
  • Tăng cường khả năng truyền thông trên mạng.
  • Cải thiện khả năng lưu trữ chung.
  • Các trình làm việc trên nền Web (Web Workers) để chạy các quá trình nền.
  • Giao diện WebSocket để thiết lập kết nối liên tục giữa các ứng dụng cư trú và máy chủ.
  • Truy vấn dữ liệu đã được lưu trữ tốt hơn.
  • Cải thiện tốc độ nạp và lưu trang.
  • Hỗ trợ cho CSS3 để quản lý giao diện người dùng đồ họa (GUI), có nghĩa là HTML5 có thể được định hướng nội dung.
  • Cải thiện xử lý biểu mẫu trình duyệt.
  • Một API cơ sở dữ liệu dựa trên-SQL cho phép lưu trữ cục bộ, phía máy khách..
  • Canvas và video, để thêm đồ họa và video mà không cần cài đặt các plug-in của bên thứ ba.
  • Đặc tả Geolocation API (API định vị toàn cầu), sử dụng khả năng định vị của máy điện thoại thông minh để kết hợp các dịch vụ và các ứng dụng đám mây di động.
  • Các biểu mẫu cải tiến làm giảm nhu cầu phải tải về mã JavaScript, cho phép truyền thông hiệu quả hơn giữa các thiết bị di động và các máy chủ điện toán đám mây.
HTML5 tạo ra sự trải nghiệm người dùng hấp dẫn hơn: Các trang được thiết kế bằng HTML5 có thể cung cấp một trải nghiệm giống như với các ứng dụng của máy tính để bàn. HTML5 cũng cung cấp phát triển nhiều nền tảng nâng cao bằng cách kết hợp khả năng của các API với sự có mặt ở khắp mọi nơi của trình duyệt. Khi sử dụng HTML5, các nhà phát triển có thể cung cấp một trải nghiệm ứng dụng hiện đại, trôi chảy qua các nền tảng.
Khi bạn nói HTML5, bạn đang sử dụng phép tốc ký cho sự đổi mới liên tục. Các thẻ mới, các phương thức mới, và một framework phát triển chung dựa trên sự tác động lẫn nhau của HTML5 và hai đối tác của nó, CSS3 và JavaScript. Đây là cốt lõi của hiện tượng xử lý ứng dụng lấy máy khách làm trung tâm. Ngoài các việc triển khai các kỹ thuật và các phương thức của công nghệ HTML5 cho máy tính để bàn, có thể triển khai thực hiện HTML5 trong nhiều trình duyệt điện thoại di động web có tính năng phong phú — một thị trường đang phát triển, khi đã chứng kiến sự phổ biến của các hệ điều hành web Apple iPhone, Google Android, và các điện thoại chạy Palm.
Một khía cạnh quan trọng về sức mạnh của HTML5 là lập bản đồ thông tin — hoặc chặn nội dung, nếu bạn thích — tạo ra một quá trình dễ hiểu hơn nhiều. Bạn có thể thấy công cụ này thích hợp cho việc thiết kế và phát triển hiệu quả như thế nào nhờ ưu thế ngày càng tăng của nó trong thế giới xử lý web.
HTML5 báo hiệu sự ra đời của một quá trình ngữ nghĩa có hiệu quả hơn ở mức văn bản và kiểm soát tốt hơn qua việc xây dựng và sử dụng các biểu mẫu. Tất cả những đặc điểm này và nhiều điểm tốt đẹp khác nữa trong sự đổi mới HTML5 là cơ sở cho sự thống trị ngày càng tăng của mô hình này. Nhiều thực thể cơ quan, thương mại và các tổ chức khác nữa — thậm chí nhiều tổ chức trong số đó hầu như liên quan rất ít đến việc xử lý thông tin và truyền thông như là hoạt động cơ quan chính của họ — theo mức độ này hay mức khác bị tràn ngập bởi sự phát triển của hiện tượng đang phát triển này.
HTML5 không phải là cây đèn thần, và cũng không có gì là thần thánh cả. Tuy nhiên, các tài sản kỹ thuật và phương pháp luận của nó đã biến nó trở thành một thứ tuyệt vời khi bạn muốn tiếp cận.
Bạn sẽ tạo một trang web đơn giản. Trong quá trình này, tôi thảo luận một số thẻ mới đã được đưa vào trong HTML5. Để có hiệu quả cao, bạn phải lập kế hoạch để xem xét tất cả các thành phần bạn muốn chế tạo.
Trang web mà bạn tạo ra sẽ có thiết kế cao cấp được hiển thị trong Hình 1. Thiết kế trang có một vùng Header (Tiêu đề), một vùng Navigation (Chuyển hướng), một vùng Article (Bài viết) có chứa ba Section (phần), một Aside (Nhận xét), và cuối cùng, là vùng Footer (Chân trang). Trang này được thiết kế để làm việc trong trình duyệt Google Chrome, trừ một số thứ lộn xộn thấy được, có thể xảy ra cùng với khả năng tương thích giữa các trình duyệt, bắt nguồn từ việc hiệu chỉnh cũng như cản trở hiểu biết về cấu trúc cơ bản. Mục đích là để tạo ra một trang mô tả rõ ràng việc sử dụng các thẻ HTML5 mới, cho thấy bạn có thể sử dụng chúng như thế nào để tạo ra mã đúng định dạng và thiết kế trang ngắn gọn.

Hình 1. Kế hoạch trang web của Acme United 
Hộp có các hộp nhỏ hơn bên trong nó hiển thị các thành phần khác nhau của trang. 
Trong quá trình tạo trang này, tôi đụng phải CSS3, cần thiết để biểu thị đúng các trang HTML5. CSS3 là cần thiết cho định kiểu, chuyển hướng, và cảm nhận chung về trang HTML5. Các nhóm đặc tính của nó, mà bạn có thể tìm thấy tại trang web tham khảo CSS3 W3Schools (xem Tài nguyên), bao gồm một số phần tử có ích như nền, phông chữ, phông màn, và hình ảnh động.
Tuy nhiên, trước khi bạn bắt đầu xây dựng trang web này, bạn cần phải tìm hiểu về một số thẻ mới của HTML5.
Vùng Header ví dụ chứa tiêu đề và phụ đề trang. Bạn sử dụng thẻ 
 để tạo ra nội dung cho vùng Header của trang. Thẻ 
 có thể chứa thông tin mở về một 
 và 
 ngoài chính trang web đó. Trang web được tạo ra ở đây có một vùng Header cho trang này, được hiển thị trong thiết kế cao cấp, cũng như vùng Header ở bên trong vùng Article và Section. Liệt kê 1 đưa ra một ví dụ đánh dấu thẻ 
.

Liệt kê 1. Ví dụ thẻ

 

Heading Text

Text or images can be included here
Logos are frequently placed here too

Thẻ 
 cũng có thể chứa một thẻ 
, như trong Liệt kê 2. Thẻ 
 tạo nhóm các tiêu đề với nhau, bằng cách sử dụng các mức tiêu đề 

 đến 
 được hiển thị ở đây có một tiêu đề chính (Main Heading) và một phụ đề (Sub-heading).

Liệt kê 2. Ví dụ thẻ
 

 

Main Heading

Sub-heading

Text or images can be included here

Bạn tạo vùng Navigation (Chuyển hướng) của trang bằng cách sử dụng thẻ . Phần tử  định nghĩa một vùng đặc biệt dành cho việc chuyển hướng. Thẻ  nên được sử dụng để chuyển hướng trang web chính, không dùng để thiết lập các liên kết có chứa trong các vùng khác của trang. Vùng Navigation này có thể chứa mã như được hiển thị trong Liệt kê 3.

Liệt kê 3. Ví dụ thẻ
 


Trang web mà bạn đang thiết kế có chứa một phần Article, giữ nội dung thực sự của trang. Bạn sử dụng thẻ 
 để tạo vùng này, và thẻ đó định nghĩa nội dung có thể được sử dụng độc lập với các nội dung khác được tìm thấy trên trang này. Ví dụ, nếu bạn muốn tạo ra một nguồn cấp dữ liệu RSS, bạn có thể sử dụng 
 để xác định nội dung duy nhất. Thẻ
 xác định nội dung có thể được gỡ bỏ và được đặt trong ngữ cảnh khác và có thể hoàn toàn dễ hiểu.
Vùng Article trong kế hoạch của Acme United có chứa ba vùng Section. Bạn tạo ra các vùng này bằng cách sử dụng thẻ
. Một 
 chứa các vùng thành phần của nội dung trang web có liên quan . Thẻ 
 — và thẻ
 nữa — có thể chứa các header (tiêu đề), các footer (chân trang), hoặc bất kỳ các thành phần nào khác cần thiết để hoàn thành phần này. Thẻ 
 dùng cho nội dung tạo nhóm. Nội dung cho cả hai thẻ 
 và thẻ 
thường bắt đầu bằng một 
 và kết thúc bằng một 
, với nội dung cho thẻ này ở giữa.
Thẻ 
 cũng có thể chứa các thẻ 
, cũng giống như thẻ 
 có thể chứa các thẻ 
. Thẻ
 nên được dùng để tạo nhóm các thông tin giống nhau, và thẻ 
 nên được sử dụng cho các thông tin như một bài viết hoặc một blog mà chúng có thể bị gỡ bỏ và được đặt trong một ngữ cảnh mới mà không ảnh hưởng đến ý nghĩa của nội dung. Thẻ 
 như tên gọi của nó, cung cấp một gói thông tin đầy đủ. Ngược lại, thẻ 
 chứa thông tin liên quan, trừ thông tin không thể được đặt trong một ngữ cảnh khác với chính nó, do nghĩa của nó sẽ bị mất.
Xem Liệt kê 4 với một ví dụ về cách sử dụng thẻ 
 và 
.

Liệt kê 4. Ví dụ thẻ
và thẻ
 

 
Content
Content
Content
Content

Cả hai thẻ 
 và thẻ 
 cũng như thẻ 
 và thẻ 
 có thể chứa thẻ 
. Bạn sử dụng thẻ này để chứa các ảnh, các sơ đồ, và các ảnh chụp.
Thẻ 
 có thể chứa thẻ 
, thẻ này chứa lần lượt các chú thích cho hình minh họa có trong thẻ 
, cho phép bạn nhập một mô tả để có thể gắn hình minh họa chặt chẽ hơn với nội dung. Liệt kê 5 đưa ra một ví dụ về cấu trúc thẻ
 và thẻ 
.

Liệt kê 5. Ví dụ thẻ
và thẻ
 

 
Picture
Caption for the figure

Các thẻ 
 và 
 cũng có thể chứa các phần tử phương tiện khác nhau. HTML5 cung cấp các thẻ để truyền đạt nhanh nội dung của chúng. Các phần tử đa phương tiện, chẳng hạn như âm thanh và video trước đây thường chỉ được nhúng vào, bây giờ có thể được sử dụng chính thống hơn.
Thẻ  xác định nội dung âm thanh, chẳng hạn như âm nhạc hoặc luồng âm thanh khác bất kỳ. Thẻ  có các thuộc tính để kiểm soát những gì, khi nào, và làm thế nào để phát âm thanh. Các thuộc tính là srcpreload (nạp trước), control (điều khiển), loop (vòng lặp), và autoplay (phát tự động). Trong ví dụ ở Liệt kê 6, âm thanh bắt đầu phát ngay sau khi tải trang này và sẽ phát liên tục, đồng thời hiển thị các nút điều khiển để người dùng có thể dừng lại hoặc phát lại âm thanh.

Liệt kê 6. Ví dụ thẻ
 


Thẻ  cho phép bạn phát các đoạn video hoặc tạo luồng phương tiện trực quan. Nó có tất cả các thuộc tính của thẻ cộng thêm ba thuộc tính nữa là: poster (quảng cáo), width (chiều rộng), và height (chiều cao). Thuộc tính postercho phép bạn xác định một hình ảnh được sử dụng trong khi video đang tải hoặc trong hoàn cảnh không may khi các video sẽ không tải được chút nào.
Liệt kê 7 cung cấp một ví dụ về cấu tạo thẻ .

Liệt kê 7. Ví dụ thẻ
 


Các thẻ  và  có thể chứa thẻ , để định nghĩa tài nguyên đa phương tiện cho các thẻ  và. Với phần tử này, bạn định rõ các tệp video và âm thanh thay thế để từ các tệp này sau đó trình duyệt có thể lựa chọn dựa vào kiểu phương tiện của mình hoặc sự hỗ trợ của codec (bộ mã hóa/giải mã). Trong Liệt kê 8, có hai sự lựa chọn. Nếu không thể phát phiên bản WMA của tệp này trong trình duyệt đang được sử dụng, thì hãy thử MP3. Nếu không, sẽ hiển thị thông báo để người sử dụng biết lý do âm thanh không có sẵn.

Liệt kê 8. Ví dụ thẻ  
 


Thẻ  định nghĩa nội dung nhúng có thể được đưa vào một trang — ví dụ, một plug-in cho các tệp SWF của Adobe Flash. Liệt kê 9 có chứa thuộc tính type (kiểu), xác định nguồn nhúng là một tệp Flash.

Liệt kê 9. Ví dụ thẻ  
 


Ngoài các thuộc tính src và type, thẻ  còn có thuộc tính height (chiều cao) và width (chiều rộng).
Bạn tạo vùng Aside theo kế hoạch Acme United bằng cách sử dụng thẻ . Hãy sử dụng thẻ này khi bạn muốn tạo nội dung bổ sung mà không còn chỗ nào để thêm vào bài viết. Trong các tạp chí, các vùng nhận xét thường được sử dụng để làm nổi bật một điểm nào đó và được thực hiện trong chính bài viết đó. Thẻ  chứa nội dung có thể được loại bỏ mà không ảnh hưởng đến các thông tin được truyền đạt bởi bài viết, phân đoạn, hoặc trang chứa nó.
Liệt kê 10 đưa ra một ví dụ về cách sử dụng thẻ .

Liệt kê 10. Ví dụ thẻ
 
My family and I visited Euro Disney last year.

Phần tử 
 chứa thông tin về một trang, bài viết, hoặc một phần, chẳng hạn như tác giả hoặc ngày viết bài. Là phần cuối trang, nó có thể chứa bản quyền hoặc các thông tin pháp lý quan trọng khác, như trong Liệt kê 11.

Liệt kê 11. Ví dụ thẻ

 
Copyright 2011 Acme United. All rights reserved.

Bây giờ bạn đã biết các thẻ cơ bản cần thiết để tạo ra một trang HTML5, chúng ta hãy bắt đầu xây dựng trang web của bạn. Bạn sẽ xây dựng một trang web cho Acme United. Trang hoàn thành được hiển thị trong Hình 2 và bạn có thể tải về để sử dụng (xemTải về).

Hình 2. Trang web Acme United
Trang web Acme United 
Nào, chúng ta hãy xây dựng một trang web. Trước tiên, có . Trong HTML5,  đã được đơn giản hóa: Tất cả mọi thứ bạn cần nhớ là html. Việc này không chỉ làm đơn giản hoá mục nhập cho thẻ này, mà cũng làm cho nó có thể nâng cấp dễ dàng hơn. Lưu ý rằng nó không được gọi là html5, mà chỉ là html. Bất kể có bao nhiêu phiên bản HTML đi nữa, thì luôn luôn có thể chỉ là html.
Thẻ  chứa tất cả các phần tử HTML khác, trừ thẻ . Tất cả các phần tử khác phải được lồng vào giữa thẻ và 
. Xem Liệt kê 12.
Liệt kê 12. Ví dụ thẻ
 



Sau khi chỉ ra nội dung là html và ngôn ngữ tiếng Anh, bạn có phần tử , có thể chứa các đoạn script (kịch bản lệnh), thông tin hỗ trợ trình duyệt, các liên kết bảng định kiểu, siêu thông tin, và các hàm khởi tạo khác. Bạn có thể sử dụng các thẻ sau trong phần head:

No comments: