LT WEB co ban
Lời nói đầu
Trong những năm gần đây, cùng với sựphát triển của Công nghệ thông tin,
mạng máy tính đang đ-ợc phát triển rộng rãi, một trong những ứng dụng phổ biến
trên mạng máy tính là Internet và các dịchvụ trở nên không thể thiếu trong cuộc
sống hiện đại. Để phục vụ việc học tập nghiên cứu của sinh viên cao đẳng CNTT,
chúng tôi biên soạn giáo trình Thiết kế và lập trình Web. Giáo trình bao gồm 5
ch-ơng, mỗi ch-ơng đều có phần kiến thức lý thuyết và câu hỏi nghiên cứu cụ thể.
Ch-ơng 1: Giới thiệu chung
Giới thiệu các khái niệm cơ bản về mạngmáy tính, Internet, địa chỉ IP, giao
thức truyền thông và các khái niệm khác.
Ch-ơng 2: Thiết kế Web với ngôn ngữ đánh dấu siêu văn bản (HTML)
Trình bày khái niệm ngôn ngữ đánh dấu siêu văn bản, các thành phần cơ bản và
cấu trúc của một tập tin HTML. Giới thiệu các vấn đề liên quan đến việc sử dụng
cú pháp và hiệu ứng của ngôn ngữ đánh dấu siêu văn bản, để lập trình Web.
Ch-ơng 3: Ngôn ngữ kịch bản trong lập trình Web
Giới thiệu hai ngôn ngữ kịch bản phổ biến hiện nay là VBScript và JavaScript.
H-ớng dẫn các b-ớc tiến hành khai báo, lập trình và sử dụng ngôn ngữ kịch bản
trong HTML.
Ch-ơng 4: Lập trình Web động với công nghệ ASP
Giới thiệu lập trình Web động với côngnghệ ASP (Active Server Page). Các
khái niệm cơ bản, các đối t-ợng cơ bản trong ASP, ứng dụng vào lập trình một
trang Web động cụ thể.
Ch-ơng 5: Kết nối cơ sở dữ liệu trong lập trình Web động với ASP
Giới thiệu ADO (ActiveX Data Object), các đối t-ợng của ADO, cách thức kết
nối với cơ sở dữ liệu, xử lý lỗi trong khi lập trình các ứng dụng. H-ớng dẫn sử dụng
các lệnh SQL trong lập trình bằng ASP. ứng dụng tổng hợp toàn bộ kiến thức để
xây dựng một trang Web động hoàn chỉnh.
Nội dung trọng tâm đ-ợc trình bày trong ch-ơng hai, ch-ơng ba và ch-ơng bốn,
cuối mỗi ch-ơng này đều có bài tập h-ớng dẫn lập trình. Giáo trình Thiết kế và lập
trình Web h-ớng dẫn cách xây dựng một ứng dụng Web từ cơ bản đến nâng cao
bằng công nghệ HTML và ASP. Đ-ợc biên soạn với ph-ơng châm đảm bảo tính
logic, khoa học, thiết thực, dễ hiểu nhằm trang bị cho sinh viên những kiến thức cơ
bản, phục vụ cho nghiên cứu, thiết kế, lập trình một ứng dụng Web hoàn chỉnh.
Tài liệu này đ-ợc tham khảo từ một số tài liệu của các tác giả trong n-ớc, tổng
hợp và l-ợc dịch từ một số tài liệu chuyên ngành của n-ớc ngoài, nên một số thuật
ngữ Tin học không thể thay thế bằng tiếng Việt. Để tiện cho việc trình bày ý t-ởng
xuyên suốt của tài liệu, chúng tôi để nguyên bản thuật ngữ tiếng Anh và giải thích
bằng thuật ngữ tiếng Việt nếu có cụm từ t-ơng đ-ơng.
Tuy có nhiều cố gắng trong công tác biên soạn, nh-ng vẫn không tránh khỏi
thiếu sót. Trong phạm vi hạn hẹp của cuốn tài liệu này, không thể đề cập đ-ợc tất
cả những vấn đề nóng hổi trong lĩnh vực thiết kế và lập trình Web đòi hỏi.
Rất mong sự đóng góp phê bình từ bạn đọc, để tài liệu đ-ợc hoàn chỉnh hơn.
Mọi ý kiến góp ý, xin gửi về Tr-ờng Sĩ quan CH-KT Thông tin.
Tác giả
Ch-ơng 1
Giới thiệu chung
1.1 Mạng máy tính
1.1.1 Định nghĩa
Trong quá trình khai thác, sử dụng máy tính cá nhân (Personal ComputerPC), việc trao đổi, sử dụng thông tin của một xã hội phát triển có nhu cầu to lớn.
Khi các máy vi tính ch-a có sự liên kết với nhau, thì việc trao đổi thông tin mất rất
nhiều thời gian để sao chép, gây nhiều phiền phức. Để giải quyết vấn đề trên với đà
phát triển của nền công nghiệp máy tính, các thiết bị đặc biệt và mạng máy tính ra
đời là một tất yếu.
Vì vậy, mạng (network) là một tập hợp các hệ thống máy tính và các thiết bị
mạng, chia sẻ dữ liệu, ch-ơng trình, tài nguyên thông qua một đ-ờng truyền kết nối
truyền thông dùng chung, trên cơ sở một hệ điều hành mạng.
Hình 1.1. Một mạng máy tính điển hình
Đ-ờng truyền là một hệ thống các thiết bịtruyền dẫn vật lý để chuyển tải các
tín hiệu sóng điện từ.
Đ-ờng truyền vật lý có thể phân làm 2 loại:
- Hữu tuyến: cáp đồng trục, cáp đôi dây xoắn, cáp quang, cáp điện thoại,
và công nghệ mới nhất hiện nay là cáp điện năng thông th-ờng.
- Vô tuyến: sóng cực ngắn (viba), tia hồng ngoại...
1.1.2 Phân loại
Hiện nay, thông th-ờng mạng máy tính đ-ợc phân loại nh-sau:
a. Mạng cục bộ - LAN (Local Area Network)
Các máy tính cá nhân và các máy tính khác trong phạm vi một khu vực hạn
chế đ-ợc nối với nhau bằng các dây cáp chất l-ợng tốt, sao cho những ng-ời sử
dụng có thể trao đổi thông tin, dùng chung các thiết bị ngoại vi, và sử dụng các
ch-ơng trình cũng nh-các dữ liệu đã đ-ợc l-u trữ trong một máy tính dành riêng
gọi là máy dịch vụ tệp.
b. Mạng diện rộng - WAN (Wide Area Network)
Các mạng lớn hơn, gọi là mạng diện rộng (Wide Area Network), dùng các
đ-ờng dây điện thoại hoặc các ph-ơng tiện liên lạc khác để liên kết lạc khác để liên
kết các máy tính với nhau trong phạm vitừ vài chục đến vài ngàn dặm.
Sự khác nhau giữa LAN và WAN: khác nhiều về quy mô và mức độ phức
tạp, mạng cục bộ có thể chỉ liên kết vài ba máy tính cá nhân và một thiết bị ngoại vi
dùng chung đắt tiền, nh-máy in laser chẳng hạn. Các hệ thống phức tạp hơn thì có
các máy tính trung tâm (máy dịchvụ tệp) và cho phép những ng-ời dùng tiến hành
thông tin với nhau thông qua th-điện tử để phân phối các ch-ơng trình nhiều ng-ời
sử dụng, và để thâm nhập vào các cơ sở dữ liệu dùng chung.
c. Mạng đô thị - MAN (Metropolitan Area Network)
Là một mạng trải dài trên một không gian địa lý lớn hơn LAN nh-ng nhỏ
hơn WAN. MAN th-ờng đ-ợc sử dụng nh-một mạng của một thành phố, một khu
công nghiệp.
d. Mạng Intranet
Là một mạng sử dụng nội bộ nh-LAN hay WAN thực hiện đ-ợc các ứng
dụng, nói cách khác là các dịch vụ của INTERNET, chủ yếu làdịch vụ WEB với
giao thức truyền tệp siêu văn bản - HTTP.
e. Mạng Internet
Một hệ thống gồm các mạng máy tính đ-ợc liên kết với nhau trên phạm vi
toàn thế giới, tạo điều kiện thuận lợi cho các dịch vụ truyền thông dữ liệu, nh-đăng
nhập từ xa, truyền các tệp tin, th-tín điện tử, và các nhóm thông tin. Internet là một
ph-ơng pháp ghép nối các mạng máy tính hiệnhành, phát triển một cách rộng rãi
tầm hoạt động của từng hệ thống thành viên
1.2 Internet
Mạng Internet ngày nay là một mạng toàn cầu, bao gồm hàng chục triệu
ng-ời sử dụng, đ-ợc hình thành từ cuối thập kỷ 60 từ một thí nghiệm của Bộ quốc
phòng Mỹ. Tại thời điểm ban đầu đó làmạng ARPAnet của Ban quản lý dự án
nghiên cứu Quốc phòng. ARPAnet là một mạng thử nghiệm phục vụ các nghiên
cứu quốc phòng, một trong những mục đích của nó là xây dựng một mạng máy tính
có khả năng chịu đựng các sự cố (ví dụ một số nút mạng bị tấn công và phá huỷ nhng mạng vẫn tiếp tục hoạt động).
Mạng cho phép một máy tính bất kỳ trên mạng liên lạc với mọi máy tính
khác. Khả năng kết nối các hệ thống máy tính khác nhau đã hấp dẫn mọi ng-ời, vả
lại đây cũng là ph-ơng pháp thực tế duy nhất để kết nối các máy tính của các hãng
khác nhau.
Mạng Internet nguyên thuỷ đ-ợc thiết kế nhằm mục đích phục vụ việc cung
cấp thông tin cho giới khoa học, nên công nghệ của nó cho phép mọi hệ thống đều
có thể liên kết với nó thông qua một cổng điện tử. Theo cách đó, có hàng ngàn hệ
máy tính hợp tác, cũng nh-nhiều hệ thống dịch vụ th-điện tử có thu phí, nh-MCI
và Compuserve chẳng hạn, đã trở nên thành viên của Internet. Với hơn hai triệu
http://www.ebook.edu.vn 4
máy chủ phục vụ chừng 20 triệu ng-ời dùng, mạng Internet đang phát triển với tốc
độ bùng nổ, mỗi tháng có thêm khoảng một triệu ng-ời tham gia mới.
Ngày nay Internet cho phép hàng trăm triệu ng-ời trên khắp thế giới liên lạc
và trao đổi thông tin với nhau thông qua tập các giao thức gọi chung là bộ giao thức
TCP/IP (Transmission Control Protocol/Internet Protocol).
1.3 Các giao thức Internet
Ban đầu, bộ giao thức Internet (còn gọi là bộ giao thức TCP/IP) đ-ợc phát
triển bởi DoD (bộ quốc phòng Mỹ) và đ-ợc đ-a vào triển khai từ năm 1982 để cung
cấp dịch vụ tăng c-ờng tín hiệu trên các liên mạng lớn, kết hợp nhiều kiểu máy tính
khác nhau. TCP/IP cho phép các loại máy tính với các kích cỡ khác nhau liên kết
với Internet để giao tiếp với nhau. Hỗ trợ trên phần lớn các hệ thống, TCP/IP trở
thành giao thức chuẩn của Internet. PhầnTCP của giao thức này đảm bảo rằng rất
cả l-ợng thông tin gửi đi đều đ-ợc nhận đầy đủ và chính xác. Phần IP cung cấp kỹ
thuật truyền dẫn các gói thông tin tới địa chỉ nhận một cách có hiệu quả. Trong
những năm gần đây, các giao thức Internetngày càng phổ biến và hình thành các
giao thức mạng phổ dụng nhất hiện nay.
Có nhiều giao thức kết hợp với bộ giao thức Internet. D-ới đây là các mô tả
một số giao thức này.
1.3.1 Giao thức điều khiển phiên truyền
Giao thức điều khiển phiên truyền (Transmission Control Protocol-TCP) là
một giao thức Internet t-ơng ứng với tầng giao vận của OSI. TCP cung cấp khả
năng chuyển tải h-ớng kết nối, song công đầy đủ (full dupplex). Khi không cần
phần điều hành chung của một tiến trình chuyển tải h-ớng kết nối thì giao thức
gam dữ liệu ng-ời dùng (User Datagram Protocol-UDP) có thể đ-ợc thay thế cho
TCP ở cấp chuyển tải (giữa các máy chủ). TCP và UDP hoạt động tại cùng một
tầng. TCP t-ơng ứng với SPX trong môi tr-ờng Netware. TCP duy trì một tuyến kết
nối logic giữa các máy tính gửi và nhận. Theo cách này, tính nguyên vẹn của phiên
truyền đ-ợc duy trì, TCP nhanh chóng phát hiệnmọi sự cố trong phiên truyền để
chỉnh lý, nh-ng ng-ợc lại, TCP không chạy nhanh bằng UDP.
TCP còn cung cấp tính năng phân chia và tập hợp các thông điệp, đồng thời
có thể chấp nhận các thông điệp có kích th-ớc bất kỳ từ các giao thức tầng phía
trên. TCP phân chia các luồng thông điệp thành các phân đoạn mà IP có thể điều
khiển và quản lý. Khi sử dụng kết hợp với IP, TCP bổ sung dịch vụ h-ớng kết nối
và tiến hành đồng bộ hoá phân đoạn, bổ sung các số chuỗi tại mức byte.
Ngoài phân chia thông điệp, TCP còn có thể duy trì nhiều cuộc đối thoại
(conversations) với các giao thức tầng phía trên và có thể cải thiện việc sử dụng
băng thông mạng bằng cách tổ hợp nhiều thông điệp vào chung một phân đoạn.
Mỗi tuyến kết nối mạch ảo đ-ợc gán một ID kết nối có tên là cổng(port) để định
danh các gam dữ liệu kết hợp với các tuyến kết nối đó.
1.3.2 Giao thức Internet
Giao thức Internet (Internet Protocol-IP) là một giao thức phi kết nối
(connectionless) cung cấp dịch vụ gam dữ liệu và các gói tin IP th-ờng đ-ợc gọi là
gam dữ liệu IP (IP datagram). IP là một giao thức chuyển gói tin thực hiện tiến
trình định địa chỉ và chọn đ-ờng. Một phần đầu IP đ-ợc nối vào các gói tin, đ-ợc
các giao thức cấp thấp hơn truyền theo dạng các khung (frame).
http://www.ebook.edu.vn 5
IP định đ-ờng các gói tin thông qua các liên mạng bằng cách vận dụng các
bảng định tuyến động (dynamic routing table) đ-ợc tham chiếu tại mỗi b-ớc nhảy.
Các phần xác định tuyến đ-ờng đ-ợc tiến hành bằng cách tham khảo thông tin thiết
bị mạng vật lý và logic, mà giao thứcphân giải địa chỉ (Address Resolution
Protocol-ARP) cung cấp.
IP thực hiện tách rời và lắp ghép lại các gói tin theo yêu cầu giới hạn kích
th-ớc các gói tin, đ-ợc định nghĩa cho các tầng vật lý và liên kết dữ liệu thực thi. IP
cũng thực hiện tính năng kiểm tra lỗi trêndữ liệu phần đầu bằng cách tổng kiểm tra
(checksum), mặc dù dữ liệu của các tầng phía trên không đ-ợc kiểm tra lỗi.
1.3.3 Giao thức gam dữ liệu ng-ời dùng
Giao thức gam dữ liệu ng-ời dùng (User Datagram Protocol-UDP) là một
giao thức tầng giao vận phi kết nối (giữa các máy chủ). UDP không cung cấp các
tín hiệu báo nhận thông điệp, thay vào đó, đơn giản là nó chỉ làm công việc chuyển
tải các gam dữ liệu.
Cũng nh-TCP, UDP vận dụng các địa chỉ cổng để bàn giao các gam dữ liệu.
Tuy nhiên, các địa chỉ cổng này không kết hợp với các mạch ảo mà chỉ đơn thuần
là định danh các tiến trình xửlý của máy chủ cục bộ.
UDP đ-ợc sử dụng nhiều hơn TCP khi khả năng bàn giao đáng tin cậy không
quan trọng bằng khả năng thực hiện cao hoặc phải giữ phần điều hành chung của
mạng ở mức thấp. Do UDP không cần thiết lập,bảo trì và kết thúc các kết nối hoặc
điều khiển luồng dữ liệu nên nóichung nó chạy nhanh hơn TCP.
UDP là giao thức tầng giao vận, đ-ợc sử dụng với giao thức quản trị mạng
đơn giản (Simple Network Management Protocol-SNMP), là giao thức quản trị
mạng chuẩn, đ-ợc dùng với các mạng TCP/IP. UDP cho phép SNMP cung cấp tính
năng quản trị mạng với phần điều hành chung ở mức tối thiểu.
1.3.4 Giao thức phân giải địa chỉ
Ba kiểu thông tin địa chỉ d-ới đây đ-ợc sử dụng trên các mạng TCP/IP:
- Địa chỉ vật lý: đ-ợc tầng vật lý và tầng liên kết dữ liệu sử dụng.
- Các địa chỉ IP: Cung cấp các ID máy chủ và mạng logic. Các địa chỉ IP
bao gồm bốn con số đ-ợc biểu diễn d-ới dạng thập phân có chấm. Ví dụ,
192.123.1.1 là một địa chỉ IP.
- Các tên nút logic: Định danh các máy chủ cụ thể bằng các ID ký tự-số.
Chúng giúp ta dễ nhớ hơn so với các địa chỉ ID toàn số. Ví dụ,
tsqtt.edu.vn là một tên nút logic (logical node name).
Căn cứ vào tên nút (node) logic mà giao thức phân giải địa chỉ (Address
Resolution Protocol-ARP) có thể xác định địa chỉ IP kết hợp với tên đó. ARP duy trì
các bảng dữ liệu phân giải địa chỉ và có thể quảng bá các gói tin đểphát hiện các địa
chỉ trên liên mạng. Các địa chỉ IP do ARP phát hiện có thể đ-ợc cung cấp cho các
giao thức tầng liên kết dữ liệu.
1.3.5 Giao thức hệ thống tên miền
Giao thức hệ thống tên miền (Domain Name System-DNS) cung cấp tính
năng phân giải tên/địa chỉ nh-một dịch vụ cho các ứng dụng trên máy khách
(client). Các hệ phục vụ DNS cho phép con ng-ời dùng tên các nút logic để truy
cập các tài nguyên trên mạng.
1.3.6 Giao thức chuyển th-đơn giản
Giao thức chuyển th-đơn giản (Simple Mail Transfer Protocol-SMTP) và
giao thức th-tín phiên bản 3 (Post Office Protocol version 3-POP3) là một giao
thức để định đ-ờng th-tín thông qua các mạng. Nó sử dụng giao thức TCP/IP.
SMTP không cung cấp một hệ giao tiếp th-cho ng-ời dùng. Quy chuẩn,
quản lý và trao đổi các thông điệp cho ng-ời dùng cuối (End user), tất cả đều phải
tiến hành bởi một phần mềm trao đổi th-tín điện tử (nh-Outlook, Eudora,...).
1.3.7 Giao thức truyền tập tin
Giao thức truyền tập tin (File TransferProtocol-FTP) là một giao thức để
dùng chung các tập tin giữa các máy chủ nối mạng. FTP cho phép ng-ời dùng đăng
nhập các máy chủ ở xa. Những ng-ời dùng đã đăng nhập có thể xem xét các th-
mục, thao tác với các tập tin, thực thi các lệnh và chạy các ch-ơng trình trên máy
chủ. FTP cũng có khả năng trao đổi các tập tin giữa các máy chủ không đồng bộ
bằng cách hỗ trợ một cấu trúc yêu cầu tập tinđộc lập với các hệ điều hành cụ thể.
1.3.8 HTTP - HyperText Transfer Protocol
Cách thức để trình duyệt WEB của ng-ời dùng nói chuyện với ch-ơng trình
Web server khi ng-ời dùng sử dung WWW. Hypertext: cách thức liên kết tham
chiếu đến những mẫu thông tin khác nhau.
1.4 Địa chỉ IP
Địa chỉ IP giúp chúng ta có thể nhận diện đ-ợc các máy mà không cần quan
tâm đến công nghệ mạng cơ sở. Ưu điểm của nó là có thể đơn giản hóa việc định
đ-ờng đi trên mạng. Ngoài ra, địa chỉ IPcòn mang tính toàn cục, nếu mạng cục bộ
nào đó đ-ợc nối vào Internet, thì toàn bộ các máy trong mạng đó sẽ đ-ợc toàn
Internet biết đến thông qua địa chỉ IP.
Địa chỉ IP đang đ-ợc sử dụng hiện tại (IPv4) có32 bit chia thành 4 octet
(mỗi octet có 8 bit, t-ơng đ-ơng 1 byte ), cách đếm đều từtrái qua phải bit 0 cho
đến bit 31, các octet tách biệt nhau bởi dấu chấm (.). Mỗi octet có thể biểu diễn
bằng các số thập phân, nhị phân hoặc thập lục phân. Đia chỉ IP bao gồm có 3 thành
phần chính :
- Bit nhận dạng lớp (Class bit)
- Định danh của mạng (Network Identifier – NET ID)
- Định danh máy chủ (Host Identifier – HOST ID)
Do tổ chức và độ lớn của các mạng cục bộ trong liên mạng khác nhau, để
thuận tiện cho việc quản lý cấp phát địa chỉ IP ng-ời ta chia địa chỉ mạng thành 5
lớp. Ký hiệu là A, B, C, D, E
Hình 1.2. Cấu trúc các lớp địa chỉ lớp IP
1 0 NET ID (14 bits) HOST ID (16 bits)
1 1 0 NET ID (21 bits) HOST ID(8 bits)
1 1 1 0 Multicast (18 bits)
1 1 1 1 0 Multicast (17 bits)
0 NET ID (7 bits) HOST ID (24 bits)
- Lớp A: Sử dụng 7 bit định danh mạng và 24 bit để định danh các trạm.
Lớp A cho phép sử dụng 27-2 mạng và 224 -2 trạm trong mỗi mạng. Lớp
này thích hợp cho các mạng có số trạm cực lớn. Tổng số khoảng hơn 2 tỉ
địa chỉ. Vùng địa chỉ lớp A có thể sử dụng gồm từ 1.0.0.1 đến
126.255.255.254.
- Lớp B: Sử dụng 14 bit định danh mạng và 16 bit để định danh các trạm.
Lớp B cho phép sử dụng 214-2 mạng và 216 -2 trạm trong mỗi mạng.
Tổng số khoảng hơn 1 tỉ địa chỉ. Vùngđịa chỉ lớp B có thể sử dụng từ
128.0.0.1 đến 191.254.255.254.
- Lớp C: Sử dụng 21 bit định danh mạng và 8 bit để định danh các trạm.
Lớp C cho phép sử dụng 221-2 mạng và 28 -2 trạm trong mỗi mạng. Lớp
này thích hợp cho các mạng nhỏ, cósố trạm trong mỗi mạng không quá
254. Tổng số khoảng hơn nửa tỉ địa chỉ. Vùng địa chỉ lớp B có thể sử
dụng từ 192.0.0.1 đến 223.255.254.254.
- Lớp D: địa chỉ lớp này đ-ợc sử dụng cho việc quảng bá (dùng để gửi IP
datagram tới một nhóm trên mạng sử dụng cùng kiểu địa chỉ).
- Lớp E: địa chỉ dự phòng trong t-ơng lai.
1.5 Các khái niệm khác
1.5.1 URL
URL (Uniform Resource Locator) là cách gọi khác của địa chỉ web. URL
bao gồm tên của giao thức (th-ờng là HTTP hoặc FTP), tiếp đến là dấu hai chấm
(:), hai dấu gạch chéo (//), sau đó là tên miền muốn kết nối đến. Ví dụ về một URL
là “http://www.vnn.vn/cntt” sẽ h-ớng dẫn trình duyệt web của chúng ta sử dụng
giao thức giao thức http để kết nốiđến máy tính www.vnn.vn, mở tệp web ngầm
định có tên là default.htm (hay index.htm) trong th-mục cntt. Tên tệp tin ngầm
định không cần gõ vào URL. Khi gõ URL cũng có thể bỏ qua tên giao thức http vì
trình duyệt lấy giao thức http làm giao thức ngầm định.
URL có một cú pháp đặc biệt. Tất cả các URL phải chính xác, thậm chí có
một ký tự sai hay thiếu một dấu chấm cũng không đ-ợc Web Server chấp nhận,
nhập sai một ký tự trong địa chỉ URL có thể dẫn chúng ta đến một Web site có nội
dung khác hoặc nhận đ-ợc thông báo Web site đó không tồn tại.
1.5.2 Hyperlink (siêu liên kết)
Hyperlink (siêu liên kết) là một thành phần cơ bản và rất cần thiết đối với
một siêu văn bản World Wide Web. Siêu liên kết giúp chúng tadễ dàng tìm kiếm
các thông tin khác nhau về một chủ đề. Một siêu liên kết là một phần văn bản (hay
hình ảnh) của trang Web, mà khi kích vào đó sẽ tự động thực hiện một trong các
thao tác sau đây:
- Đ-a đến phần khác của trang
- Đ-a đến một trang web khác trong cùng một Web site
- Đ-a đến một trang web khác trong Web site khác
- Cho phép download một file
- Chạy một ứng dụng, trình diễn một đoạn video hoặc âm thanh
Hình ảnh minh hoạ d-ới đây là một phần của trang web. Những từ gạch d-ới
thể hiện các liên kết, chỉ cần nhấn chuột vào siêu liên kết, nội dung tài liệu mà nó
trỏ tới sẽ đ-ợc hiển thị.
Hình 1.3. Minh họa một Hyperlink (siêu liên kết)
1.5.3 Web Browser (trình duyệt web)
Web Browser là một công cụ hay ch-ơng trình cho phép truy xuất và xem
thông tin trên Web. Có nhiều Web Browser để truy xuất Web, mỗi trình duyệt có
những đặc điểm khác nhau và chúng hiển thị những trang Web không hoàn toàn
giống nhau.
Các trình duyệt web bao gồm có Internet Explorer, Netscape Navigator
Communicator, Opera, Mozilla Firefox, ... Tất cả các loại trình duyệt này đều có
các phiên bản khác nhau, vàcác phiên bản mới nhất sẽcó nhiều tính năng hơn các
phiên bản tr-ớc đó. Ngoài việc truy xuất Web, các trình duyệt còn cho phép chúng
ta thực hiện các công việc khác nh-: gửi nhận email, tải các tập tin từ Web Server
về, … thông qua các Add-on và Plugin của trình duyệt.
1.5.4 Web Server (máy chủ Web)
Web Server là máy chủ trong đó chứa thông tin d-ới dạng trang Web (trang
HTML có thể chứa âm thanh, hình ảnh, video, văn bản, …). Các Web Server đ-ợc
kết nối với nhau thông qua mạng Internet, mỗi Server có địa chỉ duy nhất trên
Internet.
Thành phần chủ chốt của Web Serverlà phần mềm. Mỗi phần mềm Web
Server chạy trên một nền tảng phần cứngvà một hệ điều hành cụ thể. Một Web
Server phải có cấu hình đủ mạnh để cung cấpcác dịch vụ cho các client, đáp ứng
đồng thời nhiều yêu cầu từ client và có khả năng l-u trữ lớn cho tài nguyên Web.
Nói về chức năng và hiệunăng, các Web Server phân thành 4 nhóm chính:
- Các máy chủ truyền thông thông th-ờng.
- Máy chủ th-ơng mại.
- Máy chủ mhóm làm việc.
- Máy chủ dùng cho mục đích đặc biệt.
Các tiêu chuẩn đánh giá một Web Server:
- Hiệu năng: nền tảng hệ điều hành và xử lý đa luồng.
- Bảo mật: Thông qua địa chỉ IP, tên máy chủ của mạng con, th-mục ...
Web Oracle cung cấp ph-ơng án bảo mật thông tin theo tên ng-ời sử
dụng và khoá mã đ-ợc mã hoá hoàn toàn trong quá trình truyền thông
trên mạng.
- Truy nhập và tích hợp CSDL: Hầu hết các Web Server đều sử dụng giao
diện CGI, một số khác thì dùng giao diện lập trình ứng dụng (API) hoặc
ngôn ngữ hỏi đáp có cấu trúc SQL.
- Quản lý và quản trị Web Server: Đặc tính quan trọng của tiêu chuẩn này
là khả năng quản trị từ xa, giao diệnđồ họa và điều khiển cấu hình của
máy chủ.
1.5.5 Web Site
Web Site là một tập hợp các trang Web liên quan đến một công ty, một tập
đoàn, một tổ chức, một cá nhân hay đơn giản chỉ là một chủ đề mà nhiều ng-ời
cùng quan tâm. Ví dụ Web Site của Chính phủ (www.chinhphu.org.vn), của một cơ
quan (Bộ GD&ĐT-www.moet.edu.vn), báo chí (www.thanhnien.com.vn), của một
chủ đề (www.thuvientinhoc.vn)...
1.5.6 World Wide Web
World Wide Web (Web) là một dịch vụhay còn gọi là một công cụ trên
Internet ra đời gần đây nhất nh-ng phát triển nhanh nhất hiện nay. Nó cung cấp
một giao diện vô cùng thân thiện với ng-ời dùng, dễ sử dụng, thuận lợi và đơn giản
để tìm kiếm thông tin.
Thực chất Web không phải là một hệ thống cụ thể với tên gọi nh-trên mà là
một tập hợp các công cụ tiện ích và siêu giao diện (meta-Interface) giúp ng-ời sử
dụng có thể tự tạo ra các "siêu văn bản" và cung cấp cho những ng-ời dùng khác
trên Internet.
1.5.7 Phân biệt Inetrnet và WWW
WWW chỉ là một phần nhỏ của Internet. Internet bao hàm tất cả phần cứng
và phần mềm, bao gồm HTTP, FTP (File Transfer Protocol, sẽ đề cập đến sau),
Emails và Newgroups. WWW chủ yếu xây dựng trên các ký tự và hình ảnh mà
chúng ta có thể xem bằng các trình duyệt Web.
1.5.8 Web page
Web page là trang Web, là một loại tập tin đặc biệt đ-ợc viết bằng ngôn ngữ
siêu văn bản HTML. Web page có thể hiểncác thông tin văn bản, âm thanh, hình
ảnh, video, … Trang Web này đ-ợc đặt trên một máy chủ Web sao cho các máy
khách có thể truy cập đ-ợc nó, tập hợp nhiều trang Web có liên quan, ràng buộc
đến nhau cho chúng ta một Web Site.
1.6 Cách thức tổ chức và xây dựng một Web Site
Việc xây dựng một trang Web để đ-ợc nhiều ng-ời quan tâm là một công
việc không đơn giản. Việc thiết kế không chỉ l-u ý đến vấn đề là mọi ng-ời có truy
cập vào trang Web của mình hơn một lần hay không mà thông tin trên đó phải phụ
thuộc hoàn toàn vào mục đích của việc tạo chúng.
Để tạo đ-ợc một site hữu hiệu, ta phảichú ý đến những vấn đề sau:
- Có một mục đích rõ ràng: Đây là điểm quan trọng trong việc bắt đầu thiết
kế Web.
- Luôn luôn nghĩ đến những client-ng-ời sẽ truy cập vào site: Chúng ta
phải xét đến một số đặc điểm của ng-ời truy cập nh-là: lứa tuổi, nghề
nghiệp, sở thích, thời gian rảnh rỗi ...
- Sử dụng những mục có khả năng dowload về thật nhanh. Một trong
những lý do khiến những ng-ời truy cập vào trang Web của chúng ta cảm
thấy chán nản là phải đợi lâu cho việc lấy tin và đó chính là lúc ng-ời ta
sẽ nhấn vào nút Stop.
- Cố gắng làm cho Web Site của mình xuất hiện một cách trực quan:
không nên cho quá nhiều màu sắc hoặc không có màu sắc trong trang.
- Đừng có cố gắng cho mọi thứ vào trong một trang: Một trang Web bừa
bộn sẽ gây ra cảm giác chán nản và nhức mắt.
- Tổ chức nội dung một cách thông minh: Nên nhớ rằng site của mình tạo
ra không chỉ có "độ sâu" một bậc, dovậy chỉ có những thông tin thật cần
thiết mới cho vào trang chủ. Ví dụ: giới thiệu tên công ty, mục đích, một
số sản phẩm ...
- Kiểm tra, chạy thử site vừa thiết kế một cách kỹ tr-ớc khi đ-a lên Web
Server: Thử kiểm tra site bởi các trình duyệt Web, trên các hệ điều hành
khác nhau hay là các chế độ kích th-ớc cửa sổ khác nhau để đảm bảo
rằng site của chúng ta thông suốt.
1.7 Phân loại Web
Dựa vào đặc tr-ng, kết nối dữ liệu và công cụ phát triển ng-ời ta có thể chia
ra làm 3 loại Web sau đây:
1.7.1 Static pages (Web tĩnh ):
Tính chất của các trang Web này là chỉ bao gồm các nội dung hiển thị cho
ng-ời dùng xem. Ví dụ: hiển thị các trang dạng text, hình ảnh đơn giản chẳng hạn
nh-một cốc cà phê đang bốc khói ...
1.7.2 Form pages (Mẫu biểu):
Ngoài nội dung nh-ở trang Web tĩnh, nó còn chứa các mẫu biểu (form) cho
phép nhập các yêu cầu từ phía ng-ời sử dụng. Khi ng-ời dùng điền xong các form,
ấn nút "Submit" và tất cảc các thông tin (yêu cầu) sẽ đ-a đến đầu vào của một
ch-ơng trình CGI (Common Gateway Interface) chạy trên Server. (th-ờng thì các
CGI xử lý và cất giữ thông tin vào các file dữ liệu trên Server rồi thông báo trả lại
cho khách hàng).
Loại Web này th-ờng đ-ợc dùng để làm các phiếu điều tra, tr-ng cầu ý kiến,
mua hàng ..v..v..
1.7.3 Dynamic Web (Web động)
Nội dung của trang Web động nh-trong 1 trang Web tĩnh, ngoài ra còn có
nhúng các đoạn mã lệnh cho phép truy nhập cơ sở dữ liệu trên mạng.
Tuỳ theo nhu cầu, ứng dụng có thể cung cấp khả năng truy cập dữ liệu, tìm
kiếm thông tin, …
1.8 Câu hỏi và bài tập ch-ơng 1
Câu 1: Phân biệt mạng Intranet và mạng Internet.
Câu 2: Mạng Internet sử dụng những giaothức nào? Chứcnăng của chúng?
Câu 3: Cấu trúc các lớp của địa chỉ IP.
Câu 4: Các khái niệm URL, hyperlinks, web page, web browser, web server.
Câu 5: Phân biệt Internet và World Wide Web.
Câu 6: Cách thức xây dựng một website.
Câu 7: Phân biệt các loại web
http://www.ebook.edu.vn 11
Ch-ơng 2
Lập trình Web với ngôn ngữ đánh dấu siêu văn bản (HTML)
2.1 Khái niệm ngôn ngữ HTML
HTML viết tắt của HyperText Mark-up Language (ngôn ngữ đánh dấu siêu
văn bản). Có thể định nghĩa HTML:
Là một tập hợp các quy tắc và các thẻ (tag) đ-ợc sử dụng để quy định các
thức trình bày, hiển thị nội dung của các trang Web, tập hợp các quy tắc và thẻ này
phải tuân theo một chuẩn quốc tế, đảm bảo cho các trình duyệt Web khác nhau,trên
các nền phần cứng và hệ điều hành khác nhau đều hiểu đ-ợc và hiển thị đúng nội
dung của các trang Web.
HTML không phải là một ngôn ngữ lập trình, nó là một ngôn ngữ đánh dấu.
HTML dễ hiểu hơn nhiều so với hầu hết các ngôn ngữ lập trình.
Một tài liệu HTML là một tệp tin văn bản trong đó có sử dụng các thẻ
HTML để quy định cách thức hiển thị văn bản khi nó đ-ợc mở bởi một trình duyệt
Web.
Cơ bản các thẻ định dạng trong HTML th-ờng có từng cặp gồm: thẻ mở
<tag> và thẻ đóng </tag>.
Các văn bản nằm giữa hai thẻ này sẽ đ-ợc chịu tác động định dạng bởi thẻ.
Ví dụ, thẻ <B> dùng để định dạng chữ in đậm, khi đó văn bản "<B>Hello</B>" sẽ
đ-ợc hiển thị là "Hello".
2.2 Lập trình web với ngôn ngữ HTML
2.2.1 Các thẻ định dạng cấu trúc của HTML
Các thẻ xác định cấu trúc tài liệu là bắt buộc phải có trong một tài liệu
HTML. Sau đây chúng ta sẽ lần l-ợt học cách sử dụng các thẻ định dạng cấu trúc
của một tài liệu HTML cơ bản.
a. HTML
Cặp thẻ này đ-ợc sử dụng để xác nhận một tài liệu là tài liệu HTML, tức là
nó có sử dụng các thẻ HTML để trình bày. Toàn bộ nội dung của tài liệu đ-ợc đặt
giữa cặp thẻ này. Tất cả các tập tin HTML đều bắt đầu bằng thẻ <HTML>, thẻ này
thông báo cho trình duyệt Web biết rằng nó đang đọc một tài liệu có chứa các mã
HTML và cuối các tập tin HTML sẽ là thẻ đóng t-ơng ứng </HTML> thông báo
kết thúc một tài liệu HTML.
Cú pháp:
Trình duyệt sẽ xem các tài liệu không sử dụng thẻ <HTML> nh-những tệp
văn bản bình th-ờng.
b. HEAD
Một tài liệu HTML gồm có 2 phần: phầnmở đầu và phần nội dung chính.
Phần mở đầu giống nh-phần giới thiệu, các trình duyệt Web sử dụng phần mở đầu
này để thu nhặt các thông tin khác nhau về tài liệu HTML này, chẳng hạn nh-tiêu
<HTML>
... Toàn bộ nội dung của tài liệu đ-ợc đặt ở đây
</HTML>
<HTML>
... Phần mở đầu (header) của tài liệu đ-ợc đặt ở đây
</HTML>
<TITLE>Tiêu đề của tài liệu đ-ợc đặt ở đây</TITLE>
<BODY>
.... phần nội dung của tài liệu đ-ợc đặt ở đây
</BODY>
<HTML>
<HEAD>
<TITLE>Tiêu đề của tài liệu</TITLE>
</HEAD>
<BODY>
... Nội dung của tài liệu
</BODY>
</HTML>
đề của tài liệu, các quan hệ đ-ợc thiết lập giữa tài liệu và các th-mục. Thẻ
<HEAD> đ-ợc dùng để xác định phần mở đầu cho tài liệu.
Cú pháp:
c. TITLE
Chúng ta có thể đặt tiêu đề cho tài liệu HTML của mình. Tiêu đề này sẽ đ-ợc
hiển thị trên thanh tiêu đề của trình duyệt. Cặp thẻ này chỉ có thể sử dụng trong
phần mở đầu của tài liệu, tức là nó phải nằm trong thẻ phạm vi giới hạn bởi cặp thẻ
<HEAD>.
Cú pháp:
d. BODY
Thẻ này đ-ợc sử dụng để xác định phần nội dung chính của tài liệu. Cũng có
thể sử dụng các tham số của thẻ để đặt ảnh nền cho tài liệu, màu nền, màu văn bản
siêu liên kết, đặt lề cho trang tài liệu… Những thông tin này đ-ợc đặt ở phần tham
số của thẻ.
Cú pháp:
Trên đây là cú pháp cơ bản của thẻ <BODY>, tuy nhiên bắt đầu từ phiên
bản HTML 3.2 thì có nhiều thuộc tính đ-ợc sử dụng trong thẻ <BODY>.
Nh-vậy một tài liệu HTML cơ bản có cấu trúc nh-sau:
Sau đây là các thuộc tính chính:
BACKGROUND= Đặt một ảnh nào đó làm ảnh nền (background) cho văn
bản. Giá trị của tham số này (phần sau dấu bằng) là URL
của file ảnh. Nếu kích th-ớc ảnh nhỏ hơn cửa sổ trình
duyệt thì toàn bộ màn hình cửa sổ trình duyệt sẽ đ-ợc lát
kín bằng nhiều ảnh.
http://www.ebook.edu.vn 13
<!-- Các chú thích đ-ợc đặt ở đây -->
BGCOLOR= Đặt mầu nền cho trang khi hiển thị. Nếu cả hai tham số
BACKGROUNDvà BGCOLORcùng có giá trị thì trình
duyệt sẽ hiển thị mầu nền tr-ớc, sau đó mới tải ảnh lên
phía trên.
TEXT= Xác định màu chữ của văn bản, kể cả các đề mục.
ALINK=
VLINK=
LINK=
Xác định màu sắc cho các siêuliên kết trong văn bản.
T-ơng ứng, alink (active link) là liên kết đang đ-ợc kích
hoạt - tức là khi đã đ-ợc kích chuột lên; vlink (visited
link) chỉ liên kết đã từng đ-ợc kích hoạt;
e. Chú thích
Cặp thẻ này cho phép ng-ời biên soạn tài liệu HTML có thể thêm vào trong
các tài liệu HTML những chú thích cần thiết, hoặc có thể sử dụng cặp thẻ này để
thông báo cho trình duyệt bỏ qua một đoạn mã lệnh HTML. Các văn bản đ-ợc đặt
giữa hai thẻ này sẽ không đ-ợc trình duyệt hiển thị.
Cú pháp:
2.2.2 Các thẻ định dạng khối
a. Thẻ <P>
Thẻ <P> đ-ợc sử dụng để định dạng một đoạn văn bản.
Cú pháp:
b. Các thẻ định dạng đề mục H1/H2/H3/H4/H5/H6
HTML hỗ trợ 6 mức đề mục. Chú ý rằng đề mục chỉ là các chỉ dẫn định dạng
về mặt logic, tức là mỗi trình duyệt sẽ thể hiện đề mục d-ới một khuôn dạng thích
hợp. Có thể ở trình duyệt này là font chữ 14 point nh-ng sang trình duyệt khác là
font chữ 20 point. Đề mục cấp 1 là cao nhất và giảm dần đến cấp 6. Thông th-ờng
văn bản ở đề mục cấp 5 hay cấp 6 th-ờng có kích th-ớc nhỏ hơn văn bản thông
th-ờng.
D-ới đây là các thẻ dùng để định dạng văn bản ở dạng đề mục:
<H1> ... </H1> Định dạng đề mục cấp 1
<H2> ... </H2> Định dạng đề mục cấp 2
<H3> ... </H3> Định dạng đề mục cấp 3
<H4> ... </H4> Định dạng đề mục cấp 4
<H5> ... </H5> Định dạng đề mục cấp 5
<H6> ... </H6> Định dạng đề mục cấp 6
<P>Nội dung đoạn văn bản</P>
http://www.ebook.edu.vn 14
<PRE>Văn bản đã đ-ợc định dạng</PRE>
<UL>
<LI> Mục thứ nhất
<LI> Mục thứ hai
</UL>
c. Thẻ xuống dòng <BR>
Thẻ này không có thẻ kết thúc t-ơng ứng (</BR>), nó có tác dụng chuyển
sang dòng mới. L-u ý, nội dung văn bản trong tài liệu HTML sẽ đ-ợc trình duyệt
Web thể hiện liên tục, các khoảng trắng liềnnhau, các ký tự tab, ký tự xuống dòng
đều đ-ợc coi nh-một khoảng trắng. Để xuống dòng, ta phải sử dụng thẻ <BR>.
d. 2.4 Thẻ <PRE>
Để giới hạn đoạn văn bản đã đ-ợc định dạng sẵn ta có thể sử dụng thẻ
<PRE>. Văn bản ở giữa hai thẻ này sẽ đ-ợc thể hiện giống hệt nh-khi chúng đ-ợc
đánh vào, ví dụ dấu xuống dòng trong đoạn văn bản giới hạn bởi thẻ <PRE> sẽ có
ý nghĩa chuyển sang dòng mới (trình duyệt sẽ không coi chúng nh-dấu cách).
Cú pháp:
2.2.3 Các thẻ định dạng danh sách
Cú pháp:
Có 4 kiểu danh sách:
• Danh sách không sắp xếp ( hay không đánh số) <UL>
• Danh sách có sắp xếp (hay có đánh số) <OL>, mỗi mục trong danh
sách đ-ợc sắp xếp thứ tự.
• Danh sách thực đơn <MENU>
• Danh sách phân cấp <DIR>
Với nhiều trình duyệt, danh sách phân cấp và danh sách thực đơn giống danh
sách không đánh số, có thể dùng lẫn với nhau.Với thẻ OL ta có cú pháp sau:
Trong đó: TYPE =1 Các mục đ-ợc sắp xếp theo thứ tự 1, 2, 3...
=a Các mục đ-ợc sắp xếp theo thứ tự a, b, c...
=A Các mục đ-ợc sắp xếp theo thứ tự A, B, C...
=i Các mục đ-ợc sắp xếp theo thứ tự i, ii, iii...
=I Các mục đ-ợc sắp xếp theo thứ tự I, II, III...
Ngoài ra còn thuộc tính START= xác định giá trị khởi đầu cho danh sách.
Thẻ <LI> có thuộc tính TYPE=xác định ký hiệu đầu dòng (bullet) đứng
tr-ớc mỗi mục trong danh sách. Thuộc tính này có thể nhận các giá trị : disc(chấm
tròn đậm); circle(vòng tròn); square(hình vuông).
<OLTYPE=1/a/A/i/I>
<LI>Muc thu nhat
<LI>Muc thu hai
<LI>Muc thu ba
</OL>
2.2.4 Các thẻ định dạng ký tự
a. Các thẻ định dạng in ký tự
Sau đây là các thẻ đ-ợc sử dụng để quy định các thuộc tính nh-in nghiêng,
in đậm, gạch chân... cho các ký tự, văn bản khi đ-ợc thể hiện trên trình duyệt.
Thẻ Thuộc tính
<B> ... </B>
<STRONG> ... </STRONG>
In chữ đậm
<I> ... </I>
<EM> ... </EM>
In chữ nghiêng
<U> ... </U> In chữ gạch chân
<DFN> Đánh dấu đoạn văn bản giữahai thẻ này là định
nghĩa của một từ. Chúng th-ờng đ-ợc in
nghiêng hoặc thể hiện qua một kiểu đặc biệt nào
đó.
<S> ... </S>
<STRIKE> ... </STRIKE>
In chữ bị gạch ngang.
<BIG> ... </BIG> In chữ lớn hơn bình th-ờng bằng cách tăng kích
th-ớc font hiện thời lên một. Việc sử dụng các
thẻ <BIG> lồng nhau tạo ra hiệu ứng chữ tăng
dần. Tuy nhiên đối với mỗi trình duyệt có giới
hạn về kích th-ớc đối với mỗi font chữ, v-ợt quá
giới hạn này, các thẻ <BIG> sẽ không có ý
nghĩa.
<SMALL> ... </SMALL> In chữ nhỏ hơn bình th-ờng bằng cách giảm
kích th-ớc font hiện thời đi một. Việc sử dụng
các thẻ <SMALL>lồng nhau tạo ra hiệu ứng
chữ giảm dần. Tuy nhiên đối với mỗi trình
duyệt có giới hạn về kích th-ớc đối với mỗi font
chữ, v-ợt quá giới hạn này, các thẻ <SMALL>
sẽ không có ý nghĩa.
<SUP> ... </SUP> Định dạng chỉ số trên (SuperScript)
<SUB> ... </SUB> Định dạng chỉ số d-ới (SubScript)
<BASEFONT> Định nghĩa kích th-ớc font chữ đ-ợc sử dụng
cho đến hết văn bản. Thẻ này chỉ có một tham
số size= xác định cỡ chữ. Thẻ <BASEFONT>
không có thẻ kết thúc.
<FONT> ... </FONT> Chọn kiểu chữ hiển thị. Trong thẻ này có thể đặt
hai tham số size= hoặc color= xác định cỡ chữ
và màu sắc đoạn văn bản nằm giữa hai thẻ. Kích
th-ớc có thể là tuyệt đối (nhận giá trị từ 1 đến 7)
hoặc t-ơng đối (+2,-4...) so với font chữ hiện
tại.
http://www.ebook.edu.vn 16
<CENTER>Văn bản sẽ đ-ợc căn giữa trang</CENTER>
b. Căn lề văn bản trong trang Web
Trong trình bày trang Web của mình chúng ta luôn phải chú ý đến việc căn
lề các văn bản để trang Web có đ-ợc một bố cục đẹp. Một số các thẻ định dạng nh-
<P>, <Hn>, <IMG>... đều có tham số ALIGNcho phép căn lề các văn bản nằm
trong phạm vi giới hạn bởi của các thẻ đó.
Các giá trị cho tham số ALIGN:
LEFT Căn lề trái
CENTER Căn giữa trang
RIGHT Căn lề phải
Ngoài ra, chúng ta có thể sử dụng thẻ CENTERđể căn giữa trang một khối
văn bản.
Cú pháp:
c. Các ký tự đặc biệt
Ký tự & đ-ợc sử dụng để chỉ chuỗi ký tự đi sau đ-ợc xem là một thực thể
duy nhất. Ký tự ; đ-ợc sử dụng để tách các ký tự trong một từ.
Ký tự Mã ASCII Tên chuỗi
< < <
> > >
& & &
d. Sử dụng màu sắc trong thiết kế các trang Web
Một màu đ-ợc tổng hợp từ ba thành phần màu chính, đó là: Đỏ (Red), Xanh
lá cây (Green), Xanh n-ớc biển (Blue). Trong HTML một giá trị màu là một số
nguyên dạng hexa (hệ đếm cơ số 16) có định dạng nh-sau:
#RRGGBB
Trong đó:
RR - là giá trị màu Đỏ. GG - là giá trị màu Xanh lá cây. BB - là giá trị màu Xanh n-ớc biển.
Màu sắc có thể đ-ợc xác định qua thuộc tính bgcolor= hay color=. Sau dấu
bằng có thể là giá trị RGB hay tên tiếng Anh của màu. Với tên tiếng Anh, ta chỉ có
thể chỉ ra 16 màu trong khi với giá trị RGB ta có thể chỉ tới 256 màu.
Sau đây là một số giá trị màu cơ bản:
Màu sắc Giá trị Tên tiếng Anh
Đỏ
Đỏ sẫm
Xanh lá cây
Xanh nhạt
Xanh n-ớc biển
Vàng
Vàng nhạt
Trắng
#FF0000
#8B0000
#00FF00
#90EE90
#0000FF
#FFFF00
#FFFFE0
#FFFFFF
RED
DARKRED
GREEN
LIGHTGREEN
BLUE
YELLOW
LIGHTYELLOW
WHITE
Đen
Xám
Nâu
Tím
Tím nhạt
Hồng
Da cam
Màu đồng phục hải
quân
#000000
#808080
#A52A2A
#FF00FF
#EE82EE
#FFC0CB
#FFA500
#000080
#4169E1
#7FFFD4
BLACK
GRAY
BROWN
MAGENTA
VIOLET
PINK
ORANGE
NAVY
ROYALBLUE
AQUAMARINE
Cú pháp:
<BODY
LINK = color
ALINK = color
VLINK = color
BACKGROUND= url()
BGCOLOR = color
TEXT = color
TOPMARGIN = pixels
RIGHTMARGIN = pixels
LEFTMARGIN = pixels
>
.... phần nội dung của tài liệu đ-ợc đặt ở đây
</BODY>
Sau đây là ý nghĩa các tham số của thẻ <BODY>:
Các tham số ýnghĩa
LINK Chỉ định màu của văn bản siêu liên kết
ALINK Chỉ định màu của văn bản siêuliên kết đang đang chọn
VLINK Chỉ định màu của văn bản siêu liên kết đã từng mở
BACKGROUND Chỉ định địa chỉ của ảnh dùng làm nền
BGCOLOR Chỉ định màu nền
TEXT Chỉ định màu của văn bản trong tài liệu
SCROLL YES/NO - Xác định cóhay không thanh cuộn
TOPMARGIN Lề trên
RIGHTMARGIN Lề phải
LEFTMARGIN Lề trái
http://www.ebook.edu.vn 18
e. Chọn kiểu chữ cho văn bản
Cú pháp:
<FONT
FACE = font-name
COLOR= color
SIZE = n>
... nội dung đoạn văn bản
</FONT>
f. Khái niệm văn bản siêu liên kết
Văn bản siêu liên kết hay còn gọi là siêuvăn bản là một từ, một cụm từ hay một
câu trên trang Web đ-ợc dùng để liên kết tới một trang Web khác. Siêu văn bản là
môi tr-ờng trong đó chứa các liên kết (link) của các thông tin. Do WWW cấu thành
từ nhiều hệ thống khác nhau,cần phải có một quy tắc đặt tên thống nhất cho tất cả
các văn bản trên Web. Quy tắc đặt tên đó là URL (Universal Resource Locator).
Hình 2.1 Các thành phần của URL đ-ợc minh hoạ ở hình trên.
• Dịch vụ: Là thành phần bắt buộc của URL. Nó xác định cách thức
trình duyệt của máy khách liên lạc với máy phục vụ nh-thế nào để
nhận dữ liệu. Có nhiều dịch vụ nh- http, wais, ftp, gopher, telnet.
• Tên hệ thống: Là thành phần bắt buộccủa URL. Có thể là tên miền
đầy đủ của máy phục vụ hoặc chỉ là một phần tên đầy đủ – tr-ờng hợp
này xảy ra khi văn bản đ-ợc yêu cầu vẫn nằm trênmiền của site. Tuy
nhiên nên sử dụng đ-ờng dẫn đầy đủ.
• Cổng: Không là thành phần bắt buộc của URL. Cổng là địa chỉ socket
của mạng dành cho một giao thức cụ thể. Giao thức http ngầm định
nối với cổng 8080.
• Đ-ờng dẫn th-mục: Là thành phần bắt buộc của URL. Phải chỉ ra
đ-ờng dẫn tới file yêu cầu khi kết nốivới bất kỳ hệ thống nào. Có thể
đ-ờng dẫn trong URL khác với đ-ờng dẫn thực sự trong hệ thống máy
phục vụ. Tuy nhiên có thể rút gọn đ-ờng dẫn bằng cách đặt biệt danh
(alias). Các th-mục trong đ-ờng dẫn cách nhau bởi dấu gạch chéo (/).
• Tên file: Không là thành phầnbắt buộc của URL. Thông th-ờng máy
phục vụ đ-ợc cấu hình sao cho nếu không chỉ ra tên file thì sẽ trả về
file ngầm định trên th-mục đ-ợc yêu cầu. File này th-ờng có tên là
http://www.tsqtt.edu.vn:8080/~dir1/dir2/dir3/index.html#chapter001
Dịch vụ
Tên hệ thống
Cổng
Đ-ờng dẫn
Tên file
Các tham số, biến,
truy vấn
http://www.ebook.edu.vn 19
index.html, index.htm, default.htmlhay default.htm(với các Web site
động thì file mặc định có thể có phầnmở rộng là asp, aspx, jsp hay
php…). Nếu cũng không cócác file này thì th-ờng kết quả trả về là
danh sách liệt kê các file hay th-mục con trong th-mục đ-ợc yêu cầu
• Các tham số: Không là thành phầnbắt buộc của URL. Nếu URL là
yêu cầu tìm kiếm trên một cơ sở dữ liệu thì truy vấn sẽ gắn vào URL,
đó chính là đoạn mã đằng sau dấu chấm hỏi (?).URL cũng có thể trả
lại thông tin đ-ợc thu thập từ form. Trong tr-ờng hợp dấu thăng (#)
xuất hiện đoạn mã đăng sau là tên của một vị trí (location) trong file
đ-ợc chỉ ra.
Để tạo ra một siêu văn bản chúng ta sử dụng thẻ <A>.
Cú pháp:
<A
HREF = url
NAME = name
TABINDEX = n
TITLE = title
TARGET = _blank/ _self
>
... siêu văn bản
</A>
ýnghĩa các tham số:
Các tham số ýnghĩa
HREF Địa chỉ của trang Web đ-ợc liên kết, là một URL nào đó.
NAME Đặt tên cho vị trí đặt thẻ.
TABLEINDEX Thứ tự di chuyển khi ấn phím Tab
TITLE Văn bản hiển thị khi di chuột trên siêu liên kết.
TARGET Mở trang Web đ-ợc liên trong một cửa sổ mới (_blank) hoặc
trong cửa sổ hiện tại (_self), trong một frame (tên frame).
g. Địa chỉ t-ơng đối
URL đ-ợc trình bày ở trên là URL tuyệt đối. Ngoài ra còn có URL t-ơng đối
hay còn gọi là URL không đầy đủ. Địa chỉ t-ơng đối sử dụng sự khác biệt t-ơng
đối giữa văn bản hiện thời và văn bản cầntham chiếu tới. Các thành phần trong
URL đ-ợc ngăn cách bằng ký tự ngăn cách (ký tự gạch chéo /). Để tạo ra URL
t-ơng đối, đầu tiên phải sử dụng ký tự ngăn cách. URL đầy đủ hiện tại sẽ đ-ợc sử
dụng để tạo nên URL đầy đủ mới. Nguyên tắc là các thành phần bên trái dấu ngăn
cách của URL hiện tại đ-ợc giữ nguyên, các thành phần bên phải đ-ợc thay thế
bằng thành phần URL t-ơng đối. Chú ý rằng trình duyệt không gửi URL t-ơng đối,
nó bổ sung vào URL cơ sở đã xác định tr-ớc thành phần URL t-ơng đối xác định
sau thuộc tính href=. Ký tự đầu tiên sau dấu bằng sẽxác định các thành phần nào
của URL hiện tại sẽ tham gia để tạo nên URL mới.
Ví dụ, với địa chỉ URL: http://dit.tsqtt.edu.vn/HTML/ thì:
• Dấu hai chấm (:) chỉ dịch vụ giữ nguyên nh-ng thay đổi phần còn lại.
• Dấu gạch chéo (/) chỉ dịch vụ và máy phục vụ giữ nguyên nh-ng toàn
bộ đ-ờng dẫn thay đổi. Ví dụ /JavaScript/index.htm sẽ tải file
index.htm của th-mục JavaScript trên máy phục vụ dit.tsqtt.edu.vn.
• Không có dấu phân cách chỉ có tên file là thay đổi. Ví dụ index.htm sẽ
tải file index.htm ở trong th-mục HTML của máy phục vụ
dit.tsqtt.edu.vn.
• Dấu thăng (#): chỉ dịch vụ, máy phuc vụ, đ-ờng dẫn và cả tên file giữ
nguyên, chỉ thay đổi vị trí trong file.
Do đ-ờng dẫn đ-ợc xem là đơn vị độc lập nên có thể sử dụng ph-ơng pháp
đ-ờng dẫn t-ơng đối nh-trong UNIX hay MS-DOS (tức là dấu chấm (.)chỉ th-
mục hiện tại còn hai dấu chấm (..)chỉ th-mục cha của th-mục hiện tại).
URL cơ sở có thể đ-ợc xác định bằng thẻ <BASE>.
h. Kết nối mailto
Nếu đặt thuộc tính href=của thẻ <A> giá trị mailto:address@domain thì khi
kích hoạt kết nối sẽ kích hoạt chức năng th-điện tử của trình duyệt.
<ADDRESS>
Trang WEB này đ-ợc
<Ahref=”mailto:[email protected]” >WEBMASTER
<\A> bảo trì
<\ADDRESS>
i. Vẽ một đ-ờng thẳng nằm ngang
Cú pháp:
<HR
ALIGN = LEFT / CENTER / RIGHT
COLOR = color
NOSHADE
SIZE = n
WIDTH = width
>
ýnghĩa các tham số:
Các tham số ýnghĩa
ALIGN Căn lề (căn trái, căn phải, căn giữa)
COLOR Đặt màu cho đ-ờng thẳng
NOSHADE Không có bóng
SIZE Độ dày của đ-ờng thẳng
WIDTH Chiều dài (tính theo pixel hoặc % của bề rộng cửa sổ trình duyệt).
Thẻ này giống nh-thẻ <BR>, nó cũng không có thẻ kết thúc t-ơng ứng.
2.2.5 Các thẻ chèn âm thanh, hình ảnh
a. Giới thiệu
Liên kết với file đa ph-ơng tiện cũng t-ơng tự nh-liên kết bình th-ờng. Tuy
vậy phải đặt tên đúng cho file đa ph-ơng tiện. Phần mở rộng của file phải cho biết
kiểu của file
Kiểu Mở rộng Mô tả
Image/GIF .gif
Viết tắt của Graphics Interchange Format. Khuôn
dạng này xuất hiện khi mọi ng-ời có nhu cầu trao
đổi ảnh trên nhiều hệ thống khác nhau. Nó đ-ợc sử
dụng trên tất cả các hệ thống hỗ trợ giao diện đồ
hoạ. Định dạng GIF là định dạng chuẩn cho mọi
trình duyệt WEB. Nh-ợc điểm của nó là chỉ thể
hiện đ-ợc 256 màu.
Image/JPEG .jpeg Viết tắt của Joint Photographic Expert Group. Là
khuôn dạng ảnh khác nh-ng có thêm khả năng
nén.Ưu điểm nổi bật của khuôn dạng này là l-u trữ
đ-ợc hàng triệu màu và độ nén cao nên kích th-ớc
file ảnh nhỏ hơn và thời gian download nhanh hơn.
Nó là cơ sở cho khuôn dạng MPEG. Tất cả các trình
duyệt đều có khả năng xem ảnh JPEG.
Image/TIFF .tiff Viết tắt của Tagged Image File Format. Đ-ợc
Microsoft thiết kế để quét ảnh từ máy quét cũng
nh-tạo các ấn phẩm.
Text/HTML .html,
.htm
PostScript .eps, .ps Đ-ợc tạo ra để hiển thị vàin các văn bản có chất
l-ợng cao.
Adobe
Acrobat
.pdf Viết tắt của Portable Document Format. Acrobat
cũng sử dụng các siêu liên kết ngay trong văn bản
cũng giống nh-HTML. Từ phiên bản 2.0, các sản
phẩm của Acrobat cho phép liên kết giữa nhiều văn
bản. Ưu điểm lớn nhất của nó là khả năng
WYSISYG.
Video/MPEG .mpeg Viết tắt của Motion Picture Expert Group, là định
dạng dành cho các loại phim (video). Đây là khuôn
dạng thông dụng nhất dành cho phim trên WEB.
Video/AVI .avi Là khuôn dnạg phim do Microsoft đ-a ra.
Video/Quick
Time
.mov Do Apple Computer đ-a ra, chuẩn video này đ-ợc
cho là có nhiều -u điểm hơn MPEG và AVI. Mặc
dù đã đ-ợc tích hợp vào nhiều trình duyệt nh-ng
vẫn ch-a phổ biến bằng hai loại định dạng trên.
Sound/AU .au
http://www.ebook.edu.vn 22
Sound/MIDI .mid Là khuôn dạng dành cho âm nhạc điện tử hết sức
thông dụng đ-ợc nhiều trình duyệt trên các hệ thống
khác nhau hỗ trợ. File Midi đ-ợc tổng hợp số hoá
trực tiếp từ máy tính.
Sound/Real
Audio
.ram Định dạng audio theo dòng. Một bất tiện khi sử
dụng các định dạng khác là file âm thanh th-ờng có
kích th-ớc lớn - do vậy thời gian tải xuống lâu, Trái
lại audio dòng bắt đầu chơi ngay khi tải đ-ợc một
phần file trong khi vẫn tải về các phần khác. Mặc dù
file theo định dạng này không nhỏ hơn so với các
định dạng khác song chính khảnăng dòng đã khiến
định dạng này phù hợp với khả năng chơi ngay lập
tức.
VRML .vrml Viết tắt của Virtual Reality Modeling Language.
Các file theo định dạng này cũng giống nh-HTML.
Tuy nhiên do trình duyệt có thể hiển thị đ-ợc cửa sổ
3 chiều nên ng-ời xem có thể cảm nhận đ-ợc cảm
giác ba chiều.
b. Đ-a âm thanh vào một tài liệu HTML
Cú pháp:
<BGSOUND
SRC= url
LOOP= n
>
Thẻ này không có thẻ kết thúc t-ơng ứng (</BGSOUND>). Để chơi lặp lại
vô hạn cần chỉ định LOOP= -1hoặc LOOP= INFINITE. Thẻ <BGSOUND> phải
đ-ợc đặt trong phần mở đầu (tức là nằm trong cặp thẻ <HEAD>).
c. Chèn một hình ảnh, một đoạn video vào tài liệu HTML
Để chèn một file ảnh (.jpg, .gif, .bmp) hoặc video (.mpg, .avi) vào tài liệu
HTML, ta có thể sử dụng thẻ IMG.
Cú pháp:
<IMG
ALIGN = TOP/MIDDLE/BOTTOM
ALT = text
BORDER= n
SRC = url
WIDTH = width
HEIGHT = height
HSPACE = vspace
VSPACE = hspace
TITLE = title
DYNSRC= url
START=
FILEOPEN/MOUSEOVER
LOOP= n>
Trong đó:
Các tham số ýnghĩa
ALIGN= TOP/ MIDDLE/
BOTTOM/ LEFT/ RIGHT
Căn hàng văn bản bao quanh ảnh
ALT= text Chỉ định văn bản sẽ đ-ợc hiển thị nếu chức năng
show picture của browser bị tắt đi hay hiển thị thay
thế cho ảnh trên những trình duyệt không có khả
năng hiển thị đồ hoạ.Văn bản này còn đ-ợc gọi là
nhãn của ảnh. Đối với trình duyệt có khả năng hỗ
trợ đồ hoạ, dòng văn bản này sẽ hiện lên khi di
chuột qua ảnh hay đ-ợc hiển thị trong vùng của
ảnh nếu ảnh ch-a đ-ợc tải về hết. Chú ý phải đặt
văn bản trong hai dấu nháy kép nếu triong văn bản
chứa dấu cách hay các ký tự đặc biệt - trong tr-ờng
hợp ng-ợc lại có thể bỏ dấu nháy kép.
BORDER= n Đặt kích th-ớc đ-ờng viền đ-ợc vẽ quanh ảnh (tính
theo pixel).
SRC= url Địa chỉ của file ảnh cầnchèn vào tài liệu.
WIDTH/HEIGHT Chỉ định kích th-ớc của ảnh đ-ợc hiển thị.
HSPACE/VSPACE Chỉ định khoảng trống xung quanh hình ảnh (tính
theo pixel) theo bốn phía trên, d-ới, trái, phải.
TITLE= title Văn bản sẽ hiển thị khi con chuột trỏ trên ảnh
DYNSRC= url Địa chỉ của file video.
START=
FILEOPEN/MOUSEOVER
Chỉ định file video sẽ đ-ợc chơi khi tài liệu đ-ợc
mở hay khi trỏ con chuột vào nó. Có thể kết hợp cả
hai giá trị này nh-ng phải phân cách chúng bởi dấu
phẩy.
LOOP= n/INFINITE Chỉ định số lần chơi. Nếu LOOP = INFINITE thì
file video sẽ đ-ợc chơi vô hạn lần.
d. Image map
Image map cho phép click chuột lên một vùng nào đó trên một hình ảnh để
mở một trang Web khác. Sử dụng thẻ MAP vàAREA để thiết lập các thông tin cho
một image map.
Cú pháp:
<MAP>
<AREA SHAPE = RECT/CIRC/POLY
http://www.ebook.edu.vn 24
COORDS = coords
HREF = url
TITLE = text TARGET = _blank / _self >
<AREA ... >
<AREA ... >
...
</MAP>
Chèn ảnh:
<IMG>
Ví dụ minh họa:
<HTML>
<HEAD>
<TITLE>Image map</TITLE>
</HEAD>
<BODY>
<MAP>
<AREA
HREF="http:\\www.cse.com.vn"MsoNormal">trang chủ của CSE">
<AREA>
<AREA>
<AREA>
</MAP>
<IMG BORDER=0>
</BODY>
</HTML>
Hình 2.1 Minh họa sửdụng Images map
http://www.ebook.edu.vn 25
2.2.6 Chèn bảng
Sau đây là các thẻ chính sử dụngđể chèn bảng vào tài liệu HTML:
Thẻ Thuộc tính
<TABLE> ... </TABLE> Định nghĩa một bảng
<TR> ...</TR> Định nghĩa một hàng trong bảng
<TD> ...</TD> Định nghĩa một ô trong hàng
<TH> ...</TH> Định nghĩa ô chứa tiêu đề của cột
<CAPTION> ... </CAPTION> Tiêu đề của bảng
Cú pháp:
<TABLE
ALIGN = LEFT / CENTER / RIGHT
BORDER= n
BORDERCOLOR= color
BORDERCOLORDARK = color
BORDERCOLORLIGHT = color
BACKGROUND= url
BGCOLOR= color
CELLSPACING= spacing
CELLPADDING= pading>
<CAPTION>Tiêu đề của bảng biểu</CAPTION>
...Định nghĩa các dòng
<TR
ALIGN= LEFT/CENTER/RIGHT
VALIGN= TOP/MIDDLE/BOTTOM>
... Định nghĩa các ô trong dòng
<TD
ALIGN = LEFT / CENTER / RIGHT
VALIGN = TOP / MIDDLE / BOTTOM
BORDERCOLOR = color BORDERCOLORDARK= color
BORDERCOLORLIGHT= color
BACKBROUND = url BGCOLOR= color
COLSPAN= n
ROWSPAN= n>
... Nội dung của ô
</TD>
</TR>
</TABLE>
http://www.ebook.edu.vn 26
ýnghĩa các tham số:
Các tham số ýnghĩa
ALIGN / VALIGN Căn lề cho bảng và nộidung trong mỗi ô.
BORDER Kích th-ớc đ-ờng kẻ chia ô trong bảng, đ-ợc đo theo
pixel. Giá trị 0 có nghĩa là không xác định lề, giữa
các ô trong bảng chỉ có một khoảng trắng nhỏ để
phân biệt. Nếu chỉ để border thì ngầm định
border=1. Với những bảng có cấu trúc phức tạp, nên
đặt lề để ng-ời xem có thể phân biệt rõ các dòng và
cột.
BORDERCOLOR Màu đ-ờng kẻ
BORDERCOLORDARK
BORDERCOLORLIGHT
Màu phía tối và phía sáng cho đ-ờng kẻ nổi.
BACKGROUND Địa chỉ tới tệp ảnh dùng làm nền cho bảng
BGCOLOR Màu nền
CELLSPACING Khoảng cách giữa các ô trong bảng
CELLPADDING Khoảng cách giữa nội dung và đ-ờng kẻ trong mỗi ô
của bảng.
COLSPAN Chỉ định ô sẽ kéo dài trong bao nhiêu cột
ROWSPAN Chỉ định ô sẽ kéo dài trong bao nhiêu hàng
2.2.7 Sử dụng Khung – Frame
Các framecho phép bạn tổ chức cấu trúcnội dung các trang Web của mình
bằng cách phức hợp nhiều tài liệu HTML để có thể xem chúng trong cùng một cửa
sổ chính của trình duyệt Web. Để tạo một trang Web phức hợp bạn sử dụng các thẻ
FRAMESETvà FRAMEđể chia cửa sổ chính thành các khung chữ nhật (frame).
Sau đó trong mỗi khung hìnhchữ nhật đó bạn chỉ định một tài liệu sẽ đ-ợc hiển thị
trong khung đó. Chú ý thẻ FRAMESETsẽ thay thế cho thẻ BODYtrong một tài
liệu HTML, điều đó có nghĩa là trong một tài liệu sử dụng thẻ FRAMESETsẽ
không có thẻ BODYmà thay vào đó phần nội dung chính của tài liệu sẽ đ-ợc định
nghĩa bởi thẻ FRAMESET.
a. Thẻ FRAMESET
Cú pháp:
<FRAMESET
COLS = col-widths
ROWS = row-heights
BORDER = pixels
BORDERCOLOR = color
FRAMEBORDER = 1/0 >
...
<FRAME ... >
http://www.ebook.edu.vn 27
<FRAME ... >
...
</FRAMESET>
Trong đó:
Các tham số ýnghĩa
COLS Chia dọc cửa sổ thành các phần với kích th-ớc chỉ định (theo
pixel, % hoặc *).
ROWS Chia ngang cửa sổ thành các phần với kích th-ớc chỉ định
(theo pixel, % hoặc *).
BORDER Kích th-ớc của đ-ờng kẻ viền khung
BORDERCOLOR Chỉ định màu cho đ-ờng viền khung
FRAMEBORDER Chỉ định có/không (1/0) hiển thị khung của các frame.
b. Thẻ FRAME
Cú pháp:
<FRAME
BORDERCOLOR = color
FRAMEBORDER = 0/1
MARGINHEIGHT = height
MARGINWIDTH = width
NAME = name
NORESIZE
SCROLLING = YES/NO
SRC = address
Target = Window_Name>
Trong đó:
Các tham số ýnghĩa
BORDERCOLOR Màu đ-ờng viền khung.
FRAMEBORDER = 0 / 1 Chỉ định có/không viền khung.
MARGINHEIGHT Khoảng cách giữa nội dung trong khung và đ-ờng
viền ngang.
MARGINWIDTH Khoảng cách giữa nội dung trong khung và đ-ờng
viền dọc.
NAME Đặt tên cho khung.
NORESIZE Chỉ định không đ-ợc thay đổi kích th-ớc của khung.
SCROLLING = YES / NO Chỉ định có hay không có thanh cuộn cho khung.
SRC Địa chỉ của tài liệu sẽ đ-ợc hiển thị trong khung.
Target Chỉ ra cửa sổ nơi mà tài liệu đ-ợc hiển thị
http://www.ebook.edu.vn 28
Ví dụ minh họa:
<HTML>
<HEAD><TITLE>Frames</TITLE></HEAD>
<FRAMESET
COLS = "30%, *">
<FRAME SRC = "vd45.htm">
<FRAME SRC = "vd48.htm">
</FRAMESET>
</HTML>
Hình 2.2 Sử dụng thẻ Frame
c. Thẻ IFRAME
Sử dụng thẻ IFRAMEđể đặt một frame vào trong một tài liệu HTML.
Cú pháp:
<IFRAME
ALIGN = LEFT / CENTER /RIGHT / TOP / BOTTOM
BORDER = pixels
BORDERCOLOR = color
FRAMEBORDER = 0/1
NORESIZE
SCROLLING = YES/NO
NAME = name
SRC = url
MARGINWIDTH = pixels
MARGINHEIGHT = pixels
WIDTH = n HEIGHT = n >
</IFRAME>
http://www.ebook.edu.vn 29
Trong đó:
Các tham số ýnghĩa
ALIGN Căn lề cho khung
BORDER Kích th-ớc đ-ờng viền của khung
BORDERCOLOR Màu đ-ờng viền của khung
FRAMEBORDER = 0 / 1 Khung có đ-ờng viền hay không
NORESIZE Không đ-ợc phép thay đổi kích th-ớc của khung.
SCROLLING = YES / NO Chỉ định khung có thanh cuộn hay không
NAME Đặt tên cho khung
SRC Địa chỉ tài liệu đ-ợc hiển thị trong khung
MARGINWIDTH Khoảng cách giữa văn bản nội dung của khung và
các đ-ờng viền dọc.
MARGINHEIGHT Khoảng cách giữa văn bản nội dung của khung và
các đ-ờng viền ngang.
WIDTH Đặt chiều rộng của khung
HEIGHT Đặt chiều cao của khung
Ví dụ minh họa:
<BODY>
Đây làkhung cửa sổ tạo bởi thẻ IFRAME:
<IFRAME
SRC = "vd43.htm"
WIDTH = 500>
</IFRAME>
</BODY>
Hình 2.3 Ví dụ về IFRAME
http://www.ebook.edu.vn 30
2.2.8 FORMS
Form là thành phần giao tiếp cơ bản giữa ng-ời duyệt Web với ng-ời tạo
Web. Dữ liệu đ-ợc nhập vào Form thông qua các hộp điều khiển (control).
a. HTML Forms
Ng-ời biên soạn HTML có thể tạo ra các HTML Form để t-ơng tác với
những ng-ời đọc tài liệu của họ chẳng hạn nh-cho phép ng-ời đọc nhập vào dữ
liệu để chạy một ch-ơng trình CGI, ghi vào các nhận xét về trang Web đó. Các
HTML Form có thể chứa các hộp văn bản (textbox),hộp danh sách lựa chọn
(checkbox), nút bấm (push button), nút chọn (radio button)...
b. Tạo Form
Để tạo ra một form trong tài liệu HTML, chúng ta sử dụng thẻ FORM với cú
pháp nh-sau:
Cú pháp:
<FORM
ACTION= ulr
METHOD = GET | POST
NAME = name
TARGET = frame_name | _blank | _self
>
<!-- Các phần tử điều khiển của form -->
<INPUT...>
<INPUT...>
</FORM>
Trong đó
Các tham số ýnghĩa
ACTION Địa chỉ sẽ gửi dữ liệu tới khi form đ-ợc submit (có thể là
địa chỉ tới một ch-ơng trình CGI, một trang ASP...).
METHOD Ph-ơng thức gửi dữ liệu.
NAME Tên của form.
TARGET Chỉ định cửa sổ sẽ hiển thị kết quả sau khi gửi dữ liệu từ
form đến server.
Đặt các đối t-ợng điểu khiển (nh-hộp văn bản, ô kiểm tra, nút bấm...) vào
trang Web
c. Thẻ INPUT
Cú pháp thẻ INPUT:
<INPUT
ALIGN= LEFT | CENTER | RIGHT
TYPE= BUTTON | CHECKBOX| FILE | IMAGE |
PASSWORD | RADIO | RESET | SUBMIT | TEXT
VALUE= value
>
Ví dụ minh họa:
<HTML>
<HEAD>
<TITLE>HTML Forms</TITLE>
<BODY>
<FORM
ACTION="http://www.cse.com.vn/scripts/auth.asp">
<P>
Tên NSD<INPUT><BR>
Mật khẩu<INPUT>
</P>
<INPUT>
</FORM>
</BODY>
</HTML>
Hình 2.4 Ví dụ về thẻ INPUT trong FORM
d. Tạo một danh sách lựa chọn bằng thẻ SELECT và OPTION
Cú pháp:
<SELECT>
<OPTION VALUE=value1 SELECTED> Tên mục chọn
thứ nhất
<OPTION VALUE=value2> Tên mục chọn thứ hai
<!-- Danh sách các mục chọn -->
</SELECT>
http://www.ebook.edu.vn 32
Ví dụ minh họa:
<HTML>
<HEAD>
<TITLE>Danh sách lựa chọn</TITLE>
</HEAD>
<BODY>
<P>Thông tin:</P>
<SELECT>
<OPTION SELECTED>Thời tiết
<OPTION>Truyền hình
<OPTION>Thị truờng
<OPTION>Thời sự QT
</SELECT>
</BODY>
</HTML>
Hình 2.5 Ví dụ tạo một danh sách lựa chọn
e. Tạo hộp soạn thảo văn bản bằng thẻ TEXTAREA
Cú pháp:
<TEXTAREA
COLS=số cột
ROWS=số hàng
NAME=tên
>
Văn bản ban đầu
</TEXTAREA>
http://www.ebook.edu.vn 33
Ví dụ minh họa:
<HTML>
<HEAD>
<TITLE>Hộp soạn thảo</TITLE>
</HEAD>
<BODY>
<P >Nhận xét:</P>
<TEXTAREA>
</TEXTAREA>
</BODY>
</HTML>
Hình 2.6 Tạo hộp soạnthảo văn bản
2.3 DHTML (Dynamic HTML)
2.3.1 Định nghĩa:
Ngôn ngữ đánh dấu siêu văn bản động (Dynamic Hypertext Markup
Language) là phiên bản mởrộng của HTML và JavaScript, ngôn ngữ này đ-ợc
dùng để tạo trang thông tin trên World Wide Web. Dynamic HTML có vị trí văn
bản và đồ họa rất chính xác vì nó cho phép nội dung của trang Web thay đổi mỗi
khi ng-ời dùng nhấn, kéo hay trỏ vào nút, hình ảnh hay các thành phần khác trên
trang này.
2.3.2 Đặc điểm
Ngôn ngữ đánh dấu siêu văn bản động mang lại cho các nhà phát triển khả
năng tạo những trang Web có hình thức và tính năng nh-một ứng dụng thực sự.
HTML động cho phép ng-ời dùng định vị chính xác văn bản và hình ảnh
trên trang Web. Cả hai trình duyệt của Netscape và Microsoft và mới nhất là của
Mozilla đều hỗ trợ hệ CSS đểkiểm soát vẻ ngoài của trang Web. Ví dụ, các nhà
phát triển có thể thay đổi kiểu chữ và kíchcỡ của từng dòng tiêu đề trên Web site
một cách đơn giản bằng cách thay đổi đặc tả trong trang đơn xác định hình thức
http://www.ebook.edu.vn 34
(Cascading Style Sheet) t-ơng ứng. HTML động có cả khảnăng liên kết cơ sở dữ
liệu với trang Web để sửa đổi nộidung ngay trong khi thực thi. Tr-ớc khi trang
HTML động đ-ợc duyệt, trình duyệt phải bổ sung mã ch-ơng trình chạy ngoài
trình duyệt nh-Java hay thành phần ActiveX.
2.3.3 Một số hiệu ứng DHTML
a. Tạo chuỗi ký tự chuyển động
Cú pháp:
<MARQUEE
BEHAVIOR =type
DIRECTION =LEFT | RIGHT
LOOP =n
VSCROLLAMOUNT=n
SCOLLDELAY =n
>
Chuỗi ký tự muốn chuyển động
</MARQUEE>
Các thuộc tính:
Các tham số ýnghĩa
BEHAVIOR Xác định cách thức chuyển động, với type=scroll thì
chuỗi ký tự bắt đầu xuất hiệntại 1 cạnh của cửa sổ màn
hình và biến mất ở cạnh bên kia, với type=slide thì chuỗi
bắt đầu chuyển động từ 1 cạnh và dừng lại ở cạnh bên
kia khi chuỗi chạm vào cạnh kia, với type=alternate thì
chuỗi xuất hiện từ bên này sang bên kia và chuyển động
ng-ợc lại.
DIRECTION Định h-ớng chuyển động cho chuỗi ký tự.
LOOP Xác định số lần chuyển động của chuỗi. Nếu
loop=infinite thì chuỗi sẽ xuất hiện liên tục.
VSCROLLAMOUNT Xác định tốc độ chuyển động của chuỗi, tính bằng số
pixel/giây.
SCOLLDELAY Thời gian ngừng sau 1 lần chuyển động.
Nếu không có các thuộc tính trên thì chuyển động lặp đi lặp lại từ phải sang
trái với tốc độ 6 pixel/1 giây và thời gian ngừng giữa các lần chạy là 90 giây.
Ví dụ minh họa:
<HTML>
<HEAD>
<TITLE>Chuỗi ký tự chuyển động</TITLE>
</HEAD>
<BODY>
<P><font color=“red” face=“tahoma” size=“4”></font></P>
<MARQUEE BEHAVIOR=scroll DIRECTION=LEFT
http://www.ebook.edu.vn 35
LOOP=infinite SCROLLAMOUNT=60SCOLLDELAY=5
>Ví dụ chuỗi ký tự chuyển động trong DHTML
</MARQUEE>
</BODY>
</HTML>
b. Thay đổi hình dạng chuột khi qua một vị trí
Cú pháp:
<TD STYLE= “cursor:thuộc tính của cursor>
Các thuộc tính và hình dạng t-ơng ứng:
Auto Hand Move Text Wait Help Default Crosshair
Ví dụ minh họa:
<HTML>
<HEAD>
<TITLE>Ví dụ về Cursor</TITLE>
</HEAD>
<BODY>
<TABLE BORDER=“1”>
<TR>
<TD STYLE=“cursor:auto”>auto</TD>
<TD STYLE=“cursor:hand”>hand</TD>
<TD STYLE=“cursor:move”>move</TD>
<TD STYLE=“cursor:text”>text</TD>
<TD STYLE=“cursor:wait”>wait</TD>
<TD STYLE=“cursor:help”>help</TD>
<TD STYLE=“cursor:default”>default</TD>
<TD STYLE=“cursor:crosshair”>crosshair</TD>
</TR>
</TABLE>
</BODY>
</HTML>
2.4 Câu hỏi và bài tập ch-ơng 2
Câu 1: Khái niệm ngôn ngữ HTML?
Câu 2: Nêu các thẻ xác định cấu trúc tài liệu HTML và ý nghĩa của chúng.
Câu 3: Ngôn ngữ đánh dấu siêu văn bản động (DHTML): khái niệm, đặc
điểm.
Bài 1: Thiết kế website ch-ơng trình đào tạo cử nhân CNTT hệ cao đẳng
tr-ờng Sĩ quan CH-KT Thông tin, trang gồm 3 frame nh-hình sau, toàn bộ website
sử dụng font Time New Roman, yêu cầu:
• Top frame gồm có logo bên trái, chính giữa là banner của site, dòng
slogan chạy bên d-ới.
• Left frame là menu chính gồm các mục chính: tin tức, đào tạo, tổ
chức, tài liệu, liên kết.
• Main frame dùng thể thể hiện nội dung các mục chọn trong main
menu.
• Bottom frame (footer) là thông tin liêm hệ và bản quyền.
Logo Banner
Tin tức Slogan chuyển động
Đào tạo
Tổ chức
Tài liệu
Liên kết
Contents
Footer
Bài 2: Thiết kế website quản lýsinh viên của Hệ Dân sự d-ới dạng bảng
(table), nh-sau:
Logo Banner
Date-Time Slogan chuyển động
Tin tức-Sự kiện
Thông báo-H-ớng dẫn
Tuyển sinh-Đào tạo
Quảng cáo
Kết quả-Học bổng
Diễn đàn sinh viên
Tài liệu học tập
Liên kết website
Contents Quảng cáo
Bài 3: Thiết kế một website theo chủ đề:
• Giới thiệu danh lam thắng cảnh của quê h-ơng.
• Giới thiệu các món ẩm thực đặc sản của địa ph-ơng.
• Giới thiệu chức năng, lĩnh vực kinh doanh của một công ty.
• Giới thiệu các ấn phẩmcủa một nhà sách nhỏ.
• Giới thiệu sản phẩm may mặc của một công ty may xuất khẩu.
• Giới thiệu sản phẩm, hàng hóacho một shop bán hàng.
http://www.ebook.edu.vn 37
Ch-ơng 3
Ngôn ngữ kịch bản trong lập trình Web
3.1 JavaScript
3.1.1 Tổng quan
Với HTML và Microsoft FrontPage chúng tađã biết cách tạo ra trang Web -
tuy nhiên chỉ mới ở mức biểu diễn thông tin chứ ch-a phải là các trang Web động
có khả năng đáp ứng các sự kiện từ phía ng-ời dùng. Hãng Netscape đã đ-a ra
ngôn ngữ kịch bản có tên là LiveScript để thực hiện chức năng này. Sau đó ngôn
ngữ này đ-ợc đổi tên thành JavaScript để tận dụng tính đại chúng của ngôn ngữ lập
trình Java. Mặc dù có những điểm t-ơng đồng giữa Java và JavaScript, nh-ng
chúng vẫn là hai ngôn ngữ riêng biệt.
JavaScript là ngôn ngữ d-ới dạng script có thể gắn với các file HTML. Nó
không đ-ợc biên dịch mà đ-ợc trình duyệt diễn dịch. Không giống Java phải
chuyển thành các mã dễ biên dịch, trình duyệt đọc JavaScript d-ới dạng mã nguồn.
Chính vì vậy chúng ta có thể dễ dàng học JavaScript qua ví dụ bởi vì ta có thể thấy
cách sử dụng JavaScript trên các trang Web.
a. Đặc tính của ngôn ngữ JavaScript
JavaScript là một ngôn ngữ thông dịch (interpreter), ch-ơng trình nguồn của
nó đ-ợc nhúng (embedded) hoặc tích hợp (integated) vào tập tin HTML chuẩn. Khi
file đ-ợc load trong Browser (có support cho JavaScript), Browser sẽ thông dịch các
Script và thực hiện các công việc xác định. Ch-ơng trình nguồn JavaScript đ-ợc
thông dịch trong trang HTMLsau khi toàn bộ trang đ-ợc load nh-ng tr-ớc khi
trang đ-ợc hiển thị.
JavaScript là một ngôn ngữ có đặc tính:
• Đơn giản.
• Động (Dynamic).
• H-ớng đối t-ợng (Object Oriented).
b. Đối t-ợng trong JavaScript
Một trong những đặc tính quan trọng của ngôn ngữ JavaScriptlà khả năng
tạo và sử dụng các đối t-ợng (Object). Các Object này cho phép ng-ời lập trình sử
dụng để phát triển ứng dụng.
Trong JavaScript, các Object đ-ợc nhìn theo 2 khía cạnh:
• Các Object đã tồn tại.
• Các Object do ng-ời lập trình xây dựng.
Trong các Object đã tồn tại đ-ợc chia thành 2 kiểu:
• Các Object của chính JavaScript(JavaScript Built-in Object):
JavaScript cung cấp 1 bộ các Built-in Object để cung cấp các thông tin
về sự hiện hành của các đối t-ợng đ-ợc load trong trang Web và nội
dung của nó.Các đối t-ợng này bao gồm các ph-ơng pháp (Method)
làm việc với các thuộc tính (Properties) của nó.
• Các đối t-ợng có sẵn đ-ợc cung cấp bởi môi tr-ờng Netscape:
Netscape Navigator cung cấp các đối t-ợng cho phép JavaScript t-ơng
tác với file HTML, các đối t-ợng này cho phép chúng ta điều khiển
việc hiển thị thông tin và đáp ứng các sự kiện trong môi tr-ờng
Navigator.
c. Các đối t-ợng do ng-ời lập trình xây dựng
• Định nghĩa thuộc tính của đối t-ợng: (Object Properties)
Cú pháp
Object-name.Property-name (tên đối t-ợng.tên đặc tính)
Ví dụ: Một đối t-ợng airplane có các thuộc tính nh-sau:
Airplane.model Airplane.price
Airplane.seating Airplane.maxspeed
Airplane.fuel
• Thêm các ph-ơng pháp cho đối t-ợng: ( Method to Object)
Sau khi đã có các thông tin về airplane ta tiếp tục xây dựng ph-ơng pháp để
sử dụng thông tin này.Ví dụ muốn in ra mô tả của airplane hoặc tính toán khoảng
cách tối đa của cuộc hành trình với nhiên liệu đã có:
Airplane.description()
Airplane.distance()
• Tạo một instance (thể hiện) của đối t-ợng:
Tr-ớc khi thao tác với một đối t-ợng của JavaScript ta phải tạo một instance
cho đối t-ợng đó.
d. Nhúng JavaScript vào trong tập tin HTML
Đoạn mã JavaScript có thể đ-ợc nhúng vào một file HTML theo một trong
các cách sau đây:
• Sử dụng các câu lệnh và các hàm trong cặp thẻ <SCRIPT>
• Sử dụng các file nguồn JavaScript.
• Sử dụng một biểu thức JavaScriptlàm giá trị của một thuộc tính
HTML.
• Sử dụng thẻ sự kiện (event handlers) trong một thẻ HTML nào đó.
Trong đó, sử dụng cặp thẻ <SCRIPT>...</SCRIPT> và nhúng một file
nguồn JavaScript là đ-ợc sử dụng phổ biến nhất.
Sử dụng cặp thẻ <SCRIPT>...</SCRIPT>:
Cú pháp:
<SCRIPT LANGUAGE=”JavaScript”>
JavaScript Program
</SCRIPT>
Sử dụng tập tin JavaScript bên ngoài:
<SCRIPT LANGUAGE=”JavaScript”
SRC=”http://www.tsqtt.edu.vn/scroll.js”>
<!- - Dòng ẩn mã Script đối với các Browser không hỗ trợ
(support)
JavaScript Program
//Chú thích, tất cả những gì thuộc dòng này đều bị trình
http://www.ebook.edu.vn 39
biên dịch bỏ qua. Chúng ta cũng có thể sử dụng cặp dấu
/* */ để chú thích cho một đoạn. Dòng kết thúc việc ẩn
mã Script - - >
</SCRIPT>
Thuộc tính của thẻ SCRIPT:
• LANGUAGE: Chỉ định ngôn ngữ đ-ợc sử dụng trong Script và các
phiên bản sử dụng (ví dụ nh-: JavaScript, JavaScript.1.2).
• SRC: Địa chỉ URL chỉ đến tập tin ch-ơng trình JavaScript (*.js)
Chú ý: Các file JavaScript bên ngoài không đ-ợc chứa bất kỳ thẻ HTML nào.
Chúng chỉ đ-ợc chứa các câu lệnh JavaScript và định nghĩa hàm. Tên file của các
hàm JavaScript bên ngoài cần có đuôi .js, và server sẽ phải ánh xạ đuôi .jsđó tới
kiểu MIME application/x-javascript.
Thêm ch-ơng trình vào tập tin HTML:
<HTML>
<HEAD>
<TITLE>Listing</TITLE>
</HEAD>
<BODY>
Here is result:
<SCRIPT LANGUAGE=“Javascript”>
<!--
document.writeln(“It work<BR>”);
-->
</SCRIPT>
</BODY>
</HTML>
3.1.2 Sử dụng JavaScript
a. Cú pháp cơ bản của lệnh :
JavaScript xây dựng các hàm,các phát biểu,các toán tử và các biểu thức trên
cùng một dòng và kết thúc bằng dấu chấm phẩy (;).
Ví dụ: document.writeln("It work<BR>");
b. Các khối lệnh:
Nhiều dòng lệnh có thể đ-ợc liên kết với nhau và đ-ợc bao bởi cặp dấu
ngoặc nhọn: {}
Ví dụ:
{
document.writeln("Does It work");
document.writeln("It work!");
}
c. Xuất dữ liệu ra cửa sổ trình duyệt:
Dùng 2 ph-ơng pháp document.write() và document.writeln()
Ví dụ:
document.write(“Test”);
document.writeln(“Test”);
Lệnh document.writeln(“Test”); cho phép xuất từ “Test” ra màn hình và sau
đó đ-a con trỏ xuống đầu dòng tiếp theo.
d. Xuất các thẻ HTML từ JavaScript
Ví dụ 1:
<HTML>
<HEAD>
<TITLE>Outputting Text</TITLE>
</HEAD>
<BODY>
This is text plain <BR>
<B>
<SCRIPT LANGUAGE==“Javascript”>
<!- -
document.write(“This is text bold </B>”);
- ->
</SCRIPT>
</BODY>
</HTML>
Ví dụ 2:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
</HEAD>
<BODY>
<SCRIPT LANGUAGE=“Javascript”>
<!- -
document.write(“<IMG SRC= ‘welcome.gif’>”);
document.write(“<BR><H1>WELCOME TO WEB
DESIGN</H1>”);
- ->
</SCRIPT>
</BODY>
</HTML>
e. Sử dụng ph-ơng pháp writeln() với thẻ PRE:
<HTML>
<HEAD>
<TITLE>Outputting Text</TITLE>
</HEAD>
<BODY>
http://www.ebook.edu.vn 41
<PRE>
<SCRIPT>
<!- -
document.writeln("One,");
document.writeln("Two,");
document.write("Three");
document.write("...");
- ->
</SCRIPT>
</PRE>
</BODY>
</HTML>
f. Các ký tự đặc biệt trong chuỗi:
: New line
\t : Tab
\r : carriage return
\f : form feed
\b: backspace
Ví dụ:
document.writeln("It work!
");
g. Làm việc với các hộp hội thoại (dialog boxes):
Sử dụng hàm alert() để hiển thị thông báo trong một hộp.
Ví dụ:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
</HEAD>
<BODY>
<SCRIPT>
<!- -
alert("Welcome to Web Design");
document.write('<IMG
SRC="welcome.gif">');
- ->
</SCRIPT>
</BODY>
</HTML>
h. T-ơng tác với ng-ời sử dụng:
Sử dụng ph-ơng pháp promt() để t-ơng tác với ng-ời sử dụng.
Ví dụ 1:
<HTML>
http://www.ebook.edu.vn 42
<HEAD>
<TITLE>Listing</TITLE>
</HEAD>
<BODY>
<SCRIPT>
<!- -
document.write("Your favorite color is:");
document.writeln(prompt("enter your favorite
color:","Blue"));
- ->
</SCRIPT>
</BODY>
</HTML>
Ví dụ 2:
<HTML>
<HEAD>
<TITLE>Listing</TITLE>
</HEAD>
<BODY>
<SCRIPT>
<!- -
document.write('<IMG>');
document.write("<H1>Greeting ,");
document.writeln(prompt("enteryour name:","name"));
document.write("Welcome tonetscape navigator 2.01
</H1>");
- ->
</SCRIPT>
</BODY>
</HTML>
Sử dụng toán tử + để cộng 2 chuỗi đơn lại:
Ví dụ 3:
<HTML>
<HEAD>
<TITLE>Listing</TITLE>
</HEAD>
<BODY>
<SCRIPT>
<!- -
document.write('<IMG
SRC="welcome.gif">');
http://www.ebook.edu.vn 43
document.write("<H1>Greeting," + prompt("enter your
name:","name") + "Welcome to Web Design </H1>");
- ->
</SCRIPT>
</BODY>
</HTML>
3.1.3 Các kiểu dữ liệu trong JavaScript:
a. Dữ liệu kiểu số:
• Số nguyên: ví dụ: 720
• Số Octal: ví dụ: 056
• Số Hexa: ví dụ: 0x5F
• Số thập phân: ví dụ: 7.24, -34.2, 2E3
b. Dữ liệu kiểu chuổi:
Ví dụ: “Hello”
‘245’
“”
c. Dữ liệu kiểu Boolean:
Kết quả trả về là true hoặc false.
d. Dữ liệu kiểu null:
Trả về giá trị rỗng.
e. Dữ liệu kiểu văn bản (giống nh-kiểu chuỗi)
3.1.4 Tạo biến trong JavaScript:
Var example;
Var example=”Hello”;
Ta có thể dùng document.write(example);để xuất nội dung của một biến.
Ví dụ 1: Dùng từ khóa var để khai báo biến
<HTML>
<HEAD>
<TITLE>Listing</TITLE>
</HEAD>
<BODY>
<SCRIPT>
<!- -
var name=prompt("enter your name:","name");
- ->
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT>
<!--
http://www.ebook.edu.vn 44
document.write('<IMG>');
document.write("<H1>Greeting ," + name + " Welcome to
Web Design </H1>");
- ->
</SCRIPT>
</BODY>
</HTML>
Ví du 2: Tạo lại một giá trị mới cho biến
<HTML>
<HEAD>
<TITLE>Example</TITLE>
</HEAD>
<BODY>
<SCRIPT>
var name=prompt("enter your name:","name");
alert ("greeting " + name + " , ");
name=prompt("enter your friend's name:","friend's name");
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT>
<!--
document.write('<IMG>');
document.write("<H1>Greeting ," + name + " Welcome to
Web Design </H1>");
- ->
</SCRIPT>
</BODY>
</HTML>
3.1.5 Làm việc với biến và biểu thức:
a. Thiết lập biểu thức:
Cú pháp: <biến> <toán tử > <biểu thức>
Toán tử:
= Gán giá trị bên phải cho biến bên trái
Ví dụ: x=5
+= Cộng trái và phải, sau đó gán kết quả cho biến bên trái phép toán
Ví dụ: cho x=10, y=5
x+=y => x=15
-= Trừ bên trái cho bên phải, gán kết quả lại cho biến bên trái
x-=y => x=5
*= Nhân bên trái cho bên phải, gán kết quả cho biến bên trái
x*=y => x=50
/= Chia bên trái cho phải, gán kết quả lại cho biến bên trái
x/=y => x=2
%= Chia bên trái cho bên phải và lấy số d-gán lại cho biến bên trái
x%=y => x=0
Các toán tử khác:
Ví dụ:
x+=15+3 => x=18
8+5
32.5 * 72.3
12 % 5
Dấu ++ và dấu - - và dấu - :
Ví dụ:
x=5;
y=++x; (=> y=6 vì x tăng lên 6 sau đó gán cho y)
z=x++; (=> z=6 vì giá trị x=6 đ-ợc gán cho z)
sau đó x tăng 1 => x=7
Do đó ta có kết quả cuối cùng là:
x=7; y=6; z=6;
Ví dụ: x=5;
x=-x => x=-5
b. Phép toán Logic
&&: và
||: hoặc
! not
Ví dụ:
x=5, y=2, c=3
(x>y) && (y>c) => false
(x>y) || (c<x) => true
!x
c. Toán tử so sánh trong JavaScript:
==: bằng
!=: khác
>: lớn hơn
<: nhỏ hơn
>=: lớn hơn hoặc bằng
<=: nhỏ hơn hoặc bằng
Ví dụ:
1==1 => true
3<1 => false
5 >=4 => true
“the” != “he” => true
4==“4” => true
d. Toán tử điều kiện:
Cú pháp: (điều kiện ) ? giá trị 1 : giá trị 2
http://www.ebook.edu.vn 46
• Nếu điều kiện đúng thì trả về giá trị 1
• Nếu điều kiện sai thì trả về giá trị 2
Ví dụ:
(day=“Saturday”) ? “Weekend” : “Not Saturday”
e. Toán tử chuỗi:
“ Welcome to “ + “ Web Design”
Ví dụ:
Var welcome=”Welcome to”
welcome += “ Web Design”
=> welcome = “Welcome to Web Design”
Ví dụ : Sử dụng toán tử điều kiện để kiểm tra đầu vào
<HTML>
<HEAD>
<TITLE>Example</TITLE>
</HEAD>
<BODY>
<SCRIPT>
var;
var answer=20;
var correct='<IMG>';
var incorrect='<IMG>';
var response=prompt(question,"0");
var output = (response==answer) ? correct:incorrect;
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT>
<!--
document.write(output);
- ->
</SCRIPT>
</BODY>
</HTML>
3.1.6 Cấu trúc điều kiện if – else
Cú pháp:
if điều kiện
lệnh ;
hoặc
if điều kiện {
Mã JavaScript
}
http://www.ebook.edu.vn 47
Ví dụ:
If (day==“Saturday”) {
document.writeln(“It‘s the weekend”);
}
If (day!=“Saturday”) {
document.writeln(“It‘s not Saturday”);
}
Sử dụng cấu trúc else – ifcho ví dụ ở trên
If (day==“Saturday”) {
document.writeln(“It‘s the weekend”);
}
else {
document.writeln(“It‘s not Saturday”);
}
Cấu trúc kết hợp các lệnh iflồng nhau:
if điều kiện 1 {
Các lệnh JavaScript
if điều kiện 2 {
Các lệnh JavaScript
} else {
Các lệnh khác
}
Các lệnh JavaScript
} else {
Các lệnh khác
}
Ví dụ 1 : Sử dụng ph-ơng pháp confirm()với phát biểu if
<HTML>
<HEAD>
<TITLE>Example</TITLE>
<SCRIPT>
var;
var answer=20;
var correct='<IMG>';
var incorrect='<IMG>';
var response=prompt(question,"0");
if (response != answer) {
if (confirm("Wrong ! press OK for a second change"))
response=prompt(question,"0");
}
http://www.ebook.edu.vn 48
var output = (response ==answer ) ? correct:incorrect ;
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT>
<!--
document.write(output);
-->
</SCRIPT>
</BODY>
</HTML>
Ví dụ 2 : Sử dụng ph-ơng pháp confirm()với phát biểu if - else
<HTML>
<HEAD>
<TITLE>Example</TITLE>
<SCRIPT>
var;
var answer=20;
var correct='<IMG>';
var incorrect='<IMG>';
var response=prompt(question,"0");
if (response != answer) {
if (confirm("Wrong ! press OK for a second change"))
response=prompt(question,"0");
}else {
if (confirm("Correct ! press OK for a second question"))
{
question="What is 10*10";
answer=100;
response=prompt(question,"0");
}
}
var output = (response ==answer ) ? correct:incorrect ;
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT>
<!--
document.write(output);
-->
</SCRIPT>
http://www.ebook.edu.vn 49
</BODY>
</HTML>
3.1.7 Hàm và dối t-ợng
Trong kỹ thuật lập trình các lập trình viên th-ờng sử dụng hàm để thực hiện
một đoạn ch-ơng trình thể hiện cho một module nào đó để thực hiện một công việc
nào đó.
Trong Javascript có các hàm đ-ợc xây dựng sẵn để giúp chúng ta thực hiện
một chức năng nào đó ví dụ nh-hàm alert(), document.write(), parseInt() và ta
cũng có thể định nghĩa ra các hàm khác của mình để thực hiện một công việc nào
đó của mình, để định nghĩa hàm chúng ta theo cú pháp sau:
function function_name(parameters, arguments)
{
command block;
}
a. Truyền tham số:
function printName(name) {
document.write(“<HR>Your Name is <B><I>”);
document.write(name);
document.write(“</B></I><HR>”);
}
Ví dụ:
Gọi hàm printName() với lệnh sau printName(“Bob”);
Khi hàm printName() đ-ợc thi hành giá trị của name là "Bob", nếu gọi hàm
printName() với đối số là một biến
var user = “John”;
printName(user);
Khi đó name là “John”. Nếu muốn thay đổi giá trị của name ta có thể làm
nh-sau : name = “Mr. “ + name;
b. Phạm vi của biến:
Biến toàn cục (Global variable): có giá trị ảnh h-ởng trong toàn bộ ch-ơng
trình.
Biến cục bộ (Local variable): chỉ có giá trị ảnh h-ởng trong phạm vi hàm,
đoạn mã chứa nó.
c. Trả về các giá trị:
Ví dụ: Dùng return để trả về giá trị của biến.
function cube(number) {
var cube = number * number * number;
return cube;
}
Ví dụ:
<HTML>
http://www.ebook.edu.vn 50
<HEAD>
<TITLE>Example</TITLE>
<SCRIPT LANGUAGE=”JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
//DEFINE FUNCTION testQuestion()
function testQuestion(question) {
//DEFINE LOCAL VARIABLES FOR THE FUNCTION
var answer=eval(question);
var output= “What is ” + question + “?”;
var correct=‘<IMG SRC=“correct.gif”>’;
var incorrect=‘<IMG SRC=“incorrect.gif”>’;
//ASK THE QUESTION
var response=prompt(output,“0”);
//CHECK THE RESULT
return (response == answer) ? correct : incorrect;
}
// STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT LANGUAGE= “JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
//ASK QUESTION AND OUTPUT RESULTS
var result=testQuestion(“10 + 10”);
document.write(result);
//STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</BODY>
</HTML>
Hàm eval dùng chuyển đổi giá trị chuỗi số thành giá trị số.
Ví dụ: eval(“10*10”) trả về giá trị là 100.
d. Hàm đệ qui
Ví dụ:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
<SCRIPT LANGUAGE= “JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
//DEFINE FUNCTION testQuestion()
function testQuestion(question) {
//DEFINE LOCAL VARIABLES FOR THE FUNCTION
http://www.ebook.edu.vn 51
var answer=eval(question);
var output= “What is ” + question + “?”;
var correct= ‘<IMG SRC=“correct.gif”>’;
var incorrect= ‘<IMG SRC=“incorrect.gif”>’;
//ASK THE QUESTION
var response=prompt(output,”0");
//CHECK THE RESULT
return (response == answer) ? correct : testQuestion(question);
}
// STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT LANGUAGE= “JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
//ASK QUESTION AND OUTPUT RESULTS
var result=testQuestion(“10 + 10”);
document.write(result);
//STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</BODY>
</HTML>
Ví dụ 2:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
<SCRIPT LANGUAGE= “JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
//DEFINE FUNCTION testQuestion()
function testQuestion(question,chances) {
//DEFINE LOCAL VARIABLES FOR THE FUNCTION
var answer=eval(question);
var output= “What is ” + question + “?”;
var correct= ‘<IMG SRC=“correct.gif”>’;
var incorrect= ‘<IMG SRC=“incorrect.gif”>’;
//ASK THE QUESTION
var response=prompt(output,“0”);
//CHECK THE RESULT
if (chances > 1) {
return (response == answer) ? correct : testQuestion(question,chances-1);
} else {
http://www.ebook.edu.vn 52
return (response == answer) ? correct : incorrect;
}
}
// STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT LANGUAGE=“JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
//ASK QUESTION AND OUTPUT RESULTS
var result=testQuestion(“10 + 10”,3);
document.write(result);
//STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</BODY>
</HTML>
3.1.8 Tạo đối t-ợng trong JavaScript
a. Định nghĩa thuộc tính của đối t-ợng:
function student(name,age, grade) {
this.name = name;
this.age = age;
this.grade = grade;
}
Để tạo một Object ta sử dụng phát biểu new.
Ví dụ để tạo đối t-ợng student1, ta sử dụng khai báo:
student1 = new student(“Bob”,10,75);
Ba thuộc tính của đối t-ợng student1là :
student1.name, student1.age, student1.grade
Ví dụ để tạo đối t-ợng student2:
student2 = new student(“Jane”,9,82);
Để thêm thuộc tính cho student1, ta có thể làm nh-sau:
student1.mother = “Susan”;
Hoặc chúng ta có thể định nghĩa lại hàm student
function student(name,age, grade,mother) {
this.name = name;
this.age = age;
this.grade = grade;
this.mother = mother;
}
b. Đối t-ợng là thuộc tính của đối t-ợng khác
Ví dụ:
function grade (math, english, science) {
this.math = math;
this.english = english;
this.science = science;
}
bobGrade = new grade(75,80,77);
janeGrade = new grade(82,88,75);
student1 = new student(“Bob”,10,bobGrade);
student2 = new student(“Jane”,9,janeGrade);
student1.grade.math: dùng để lấy điểm Toán của student1
student2.grade.science: dùng lấy điểm môn Khoa học của student2
c. Thêm ph-ơng thức cho đối t-ợng:
function displayProfile() {
document.write(“Name: “ + this.name + “<BR>”);
document.write(“Age: “ + this.age + “<BR>”);
document.write(“Mother’s Name: “ + this.mother + “<BR>”);
document.write(“Math Grade: “ + this.grade.math + “<BR>”);
document.write(“English Grade: “ + this.grade.english + “<BR>”);
document.write(“Science Grade: “ + this.grade.science + “<BR>”);
}
function student(name,age, mother,grade) {
this.name = name;
this.age = age;
this.grade = grade;
this.mother = mother;
this.displayProfile = displayProfile;
}
student1.displayProfile();
Ví dụ:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
<SCRIPT LANGUAGE=”JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
//DEFINE METHOD
function displayInfo() {
document.write(“<H1>Employee Profile: ” + this.name +
“</H1><HR><PRE>”);
document.writeln(“Employee Number: ” + this.number);
document.writeln(“Social SecurityNumber: ” + this.socsec);
document.writeln(“Annual Salary: ” + this.salary);
document.write(“</PRE>”);
}
//DEFINE OBJECT
function employee() {
this.name=prompt(“Enter Employee’s Name”,”Name”);
this.number=prompt(“Enter Employee Number for “ +
this.name,”000-000");
this.socsec=prompt(“Enter SocialSecurity Number for “ +
this.name,”000-00-0000");
this.salary=prompt(“Enter Annual Salary for “ +
this.name,”$00,000");
this.displayInfo=displayInfo;
}
newEmployee=new employee();
// STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</HEAD>
<BODY>
<SCRIPT LANGUAGE=”JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
newEmployee.displayInfo();
// STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</BODY>
</HTML>
Hình 3.1 Form nhập tên nhân viên
Hình 3.2 Form nhập mức l-ơng
http://www.ebook.edu.vn 55
Hình 3.3 Form hiển thị kết quả
Ví dụ:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
<script>
<!-- Begin
var;
var;
var;
var;
var;
var;
mydate = new Date();
myday = mydate.getDay();
mymonth = mydate.getMonth();
myweekday= mydate.getDate();
weekday= myweekday;
myyear= mydate.getYear();
year = myyear;
myhours = mydate.getHours();
ampmhour = (myhours > 12) ? myhours - 12 : myhours;
ampm = (myhours >= 12) ? 'Buổ i Chiề u ' : ' Buổ i Sá ng ';
mytime = mydate.getMinutes();
myminutes = ((mytime < 10) ? ':0' : ':') + mytime;
if(myday == 0)
day = " Chủ Nhật , ";
else if(myday == 1)
day = " Thứ hai, ";
http://www.ebook.edu.vn 56
else if(myday == 2)
day = " Thứ ba, ";
else if(myday == 3)
day = " Thứ t-, ";
else if(myday == 4)
day = " Thứ năm, ";
else if(myday == 5)
day = " Thứ sáu , ";
else if(myday == 6)
day = " Thứ bảy , ";
if(mymonth == 0) {
month = "tháng một ";}
else if(mymonth ==1)
month = "tháng hai ";
else if(mymonth ==2)
month = "tháng ba ";
else if(mymonth ==3)
month = "tháng t-";
else if(mymonth ==4)
month = "tháng năm, ";
else if(mymonth ==5)
month = "tháng sáu ";
else if(mymonth ==6)
month = "tháng bảy ";
else if(mymonth ==7)
month = "tháng tám ";
else if(mymonth ==8)
month = "tháng chín ";
else if(mymonth ==9)
month = "tháng m-ời ";
else if(mymonth ==10)
month = "tháng m-ời một ";
else if(mymonth ==11)
month = "tháng m-ời hai ";
// End -->
</script>
</HEAD>
<!--Trong phan co the xuat ra nhu sau: -->
<BODY>
<SCRIPT>
<!-- HIDE FROM OTHER BROWSERS
http://www.ebook.edu.vn 57
document.write("<b><font color=#0000ff face=”tahoma,
helvetica, arial'>" + ampmhour+ "" + myminutes + ampm)
document.write(" - " + day + " ngày " + myweekday +" ");
document.write( month + " , năm " + year + "</font>");
// STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</BODY>
</HTML>
Sau khi duyệt sẽcho kết quả nh-sau:
Hình 3.4 Kết quả của đoạn scripthiển thị ngày giờ hệ thống
3.1.9 Sự kiện trong JavaScript
Các sự kiện cung cấp các t-ơng tác với cửa sổ trình duyệt và tài liệu hiện
hành đang đ-ợc load trong trang web, các hành động của user khi nhập dữ liệu vào
form và khi click vào các button trong form.
Khi sử dụng bộ quản lý sự kiện bạn có thể viết các hàm để biểu diễn cho các
hành động dựa vào các sự kiện đựoc chọn.
a. Bảng sự kiện trong Javascript
Tên sự kiện Mô tả
Blur Xảy ra khi điểm tập trung của đầu vào đ-ợc di chuyển
ra khỏi một thành phần của Form (Khi click ra ngoài
một tr-ờng)
Click Khi user Click vào 1 link hoặc thành phần của Form.
Change Xảy ra khi giá trị của Form Field bị thay đổi bởi user.
Focus Xảy ra khi ngõ vào tập trung vào thành phần của Form
Load Xảy ra khi một trang đ-ợc Load vào trong bộ duyệt.
Mouseover Xảy ra khi User di chuyển mouse qua một Hyperlink.
Select Xảy ra khi User chọn 1 tr-ờng của thành phần Form.
Submit Xảy ra khi User xác nhận đã nhập xong dữ liệu.
Unload Xảy ra khi User rời khỏi trang Web.
http://www.ebook.edu.vn 58
b. Bộ quản lý sự kiện (Event Handler)
Để quản lý các sự kiện trong javascript ta dùng các bộ quản lý sự kiện.
Cú pháp của một bộ quản lý sự kiện:
<HTML_TAG OTHER_ATTRIBUTES eventHandler=”JavaScript Program”>
Ví dụ:
<INPUT TYPE=”text” onChange=”checkField(this)”>
Ví dụ:
<INPUT TYPE=”text” onChange=“if (parseInt(this.value) <= 5)
{
alert(‘Please enter a number greater than 5.’);
}
“>
Ví dụ:
<INPUT TYPE=”text” onChange=“
alert(‘Thanks for the entry.’);
confirm(‘Do you want to continue?’);
“>
Từ khóa this: quy cho đối t-ợng hiện hành, trong Javascript, Form là một
đối t-ợng. Các thành phần của Form bao gồm text fields, checkboxes, radio
buttons, buttons, và selection lists.
c. Các bộ quản lý sự kiện trong Javascript
Đối t-ợng Bộ quản lý sự kiện t-ơng ứng.
Selection list onBlur, onChange, onFocus
Text element onBlur, onChange, onFocus, onSelect
Textarea element onBlur, onChange, onFocus, onSelect
Button element onClick
Checkbox onClick
Radio button onClick
Hypertext link onClick, onMouseOver
Reset button onClick
Submit button onClick
Document onLoad, onUnload
Window onLoad, onUnload
Form onSubmit
d. Cách dùng bộ quản lý sự kiện onLoad & onUnload
<HTML>
<HEAD>
<TITLE>Example 5.1</TITLE>
</HEAD>
<BODY onLoad=”alert(‘Welcome to my page!’);”
onUnload=”alert(‘Goodbye! Sorry to see you go!’);”>
<IMG SRC=”title.gif”>
http://www.ebook.edu.vn 59
</BODY>
</HTML>
Ví dụ 1:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
<SCRIPT LANGUAGE=”JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
var name = “”;
// STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</HEAD>
<BODY onLoad=”
name = prompt(‘Enter Your Name:’,’Name’);
alert(‘Greetings ‘ + name + ‘,welcome to my page!’);”
onUnload=” alert(Goodbye ‘ + name + ‘, sorry to see you go!’);”>
<IMG SRC=”title.gif”>
</BODY>
</HTML>
Ví dụ 2:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
<SCRIPT LANGUAGE=”JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
// DEFINE GLOBAL VARIABLE
var name = “”;
function hello() {
name = prompt(‘Enter Your Name:’,’Name’);
alert(‘Greetings ‘ + name + ‘, welcome to my page!’);
}
function goodbye() {
alert(Goodbye ‘ + name + ‘, sorry to see you go!’);
}
// STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</HEAD>
<BODY onLoad=”hello();” onUnload=”goodbye();”>
<IMG SRC=”title.gif”>
</BODY>
</HTML>
http://www.ebook.edu.vn 60
e. Các sự kiện và Form
Các sự kiện đ-ợc sử dụng để truy xuất Form nh-: onClick, onSubmit,
onFocus, onBlur, và onChange.
Ví dụ 1:
<INPUT TYPE=text NAME=”test” VALUE=”test”
onBlur=”alert(‘Thank You!’);”
onChange=”check(this);”>
Khi giá trị thay đổi function check()sẽ đ-ợc gọi. Ta dùng từ khóa thisđể
chuyển đối t-ợng của tr-ờng hiện hành đến hàm check(). Chúng ta cũng có thể dựa
vào các ph-ơng pháp và các thuộc tính của đối t-ợng bằng phát biểu sau:
this.methodName() & this.propertyName.
Ví dụ 2:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
<SCRIPT LANGUAGE=”JavaScript”>
<!-- HIDE FROM OTHER BROWSERS
function calculate(form) {
form.results.value = eval(form.entry.value);
}
function getExpression(form) {
form.entry.blur();
form.entry.value = prompt(“Please enter a JavaScript
mathematical expression”,””);
calculate(form);
}
//STOP HIDING FROM OTHER BROWSERS -->
</SCRIPT>
</HEAD>
<BODY>
<FORM METHOD=POST>
Enter a JavaScript mathematical expression:
<INPUT TYPE=text NAME=”entry” VALUE=””
onFocus=”getExpression(this.form);”>
<BR>
The result of this expression is:
<INPUT TYPE=text NAME=”results” VALUE=””
onFocus=”this.blur();”>
</FORM>
</BODY>
</HTML>
http://www.ebook.edu.vn 61
Hình 3.5 Các sự kiện trên form
formObjectName.fieldname: Dùng để chỉ tên tr-ờng của hiện hành trong form.
formObjectName.fieldname.value: Dùng lấy giá trị của tr-ờng form hiện hành.
3.1.10 Sử dụng vòng lặp trong JavaScript
a. Vòng lặp for :
Cú pháp :
for ( init value ; condition ; update expression )
Ví dụ 1:
for (i = 0 ; i < 5 ; i++)
{
lệnh ;
}
Ví dụ 2:
<HTML>
<HEAD>
<TITLE> for loop Examle </TITLE>
</HEAD>
<BODY>
<SCRIPT>
<!- -
var name=prompt("What is your name?" ,"name");
var query= " " ;
document.write("<H1>" + name + " 's 10 favorite foods </H1> ");
for (var i=1 ;i<=10;i++)
{
document.write(i + " " + prompt('Enter food number ' + i,
'food' ) + '<BR>');
}
http://www.ebook.edu.vn 62
- ->
</SCRIPT>
</BODY>
</HTML>
b. Vòng lặp while :
Cú pháp:
While ( điều kiện)
{
lệnh JavaScript ;
}
Ví dụ 1:
var num=1;
while(num<=10)
{
document.writeln(num);
num++;
}
Ví dụ 2:
var answer=” “ ;
var correc=100;
var question=” what is 10*10 ?” ;
while(answer!=correct)
{
answer=prompt(question,”0”);
}
c. Tạo mảng với vòng lặp for:
function createArray(num)
{
this.length=num;
for ( var j=0 ; j<num; j++)
this[j]=0;
}
Hàm sẽ tạo một mảng có giá trị index bắt đầu là 0 và gán tất cả các giá trị
của mảng về 0 .
Để sử dụng đối t-ợng mảng ta có thể làm nh-sau:
newArray= new createArray(4);
Sẽ tạo ra một mảng gồm4 thành phần newArray[0] … newArray[3]
3.1.11 Sử dụng đối t-ợng Windows
Window là đối t-ợng của môi tr-ờng Navigator, ngoài các thuộc tính
Window đối t-ợng window còn giữ các đối t-ợng khác mà có thể đ-ợc xem nh-là
các thành phần (member) của window, các đối t-ợng đó là:
• Các frame đã đ-ợc tạo
• Các đối t-ợng location và histtory
• Đối t-ợng document
Đối t-ợng document chứa (encompasses) tất cả các thành phần trong trang
HTML. Đây là một đối t-ợng hoàn hảo có các đối t-ợng khác của JavaScript gán
(attached) vào nó (nh-là anchor, form, history, link). Hầu nh-mọi ch-ơng trình
JavaScript đều cósử dụng đối t-ợng này để tham khảo đến các thành phần trong
trang HTML.
a. Các thuộc tính (properties) của đối t-ợng document
• alink
• anchor
• bgColor
• cookies
• fgColor
• form
• lastModified
• linkColor
• links
• location
• referrer
• title
• vlinkColor
b. Các hành vi (Methods) của đối t-ợng document
• clear()
• close()
• open()
• write()
• writeln()
c. Các thuộc tính của đối t-ợng Window
• defaultStatus : Giá trị mặt nhiên đ-ợc hiển thị ở thanh trạng thái.
• frames: Mảng các đối t-ợng chứa đựng một mục cho mỗi frame con
trong một frame tài liệu.
• parent: Đ-ợc sử dụng trong FRAMSET
• self: Cửa sổ hiện hành , dùng để phânbiệt giữa các cửa sổ hiện hành
và các forms có cùng tên.
• status: Giá trị của chuỗi văn bản đ-ợc hiển thị tại thanh status bar.
Dùng để hiển thi các thông báo cho ng-ời sử dụng.
• top: Đỉnh cao nhất của cửa sổ cha.
• window
d. Các hành vi (Methods) của đối t-ợng window
• alert(): Hiện 1 thông báo trong hộp thoại với OK button.
http://www.ebook.edu.vn 64
• close(): Đóng cửa sổ hiện hành.
• open(): Mở một cửa sổ mới với 1 tài liệu đ-ợc chỉ ra hoặc mở một tài
liệu trong một tên cửa sổ đ-ợc chỉ định.
• prompt(): Hiện một hộp thông báo.
• setTimeout():
• clearTimeout(): Hành vi này cung cấp cách gọi phát biểu JavaScript
sau một khoảng thời gian trôi qua. Ngoài ra đối t-ợng window có thể
thực hiện event handler: onLoad=statement.
3.1.12 Làm việc với status bar
Khi user di chuyển qua một hyperlink tacó thể hiện ra một thông báo tại
thanh status bar của browser dựa vào event handler onMouseOver và bằng cách đặt
self.status là một chuỗi (hoặc window.status).
Ví dụ:
<HTML>
<HEAD>
<TITLE>Status Example</TITLE>
<BODY>
<A HREF=”plc.htm” onMouseOver=”self.status=’Chuyen de PLC’;
return true ; “ >
Lop chuyen dề PLC </A>
<A HREF=”tkweb.htm” onMouseOver=”self.status=’Thiet Ke
Trang Web’ ;
return true ; “ >
Thiet Ke Web</A>
</BODY>
</HTML>
3.1.13 Mở và đóng các cửa sổ
Sử dụng ph-ơng thức open()và close()ta có thể điều khiển việc mở và đóng
cửa sổ chứa tài liệu:
open (“URL” , “WindowName” , “featureList”) ;
Các đặc điểm trong ph-ơng pháp open() gồm có:
• toolbar: tạo một toolbar chuẩn
• location: tạo một vùng location
• directories: tạo các button th-mục chuẩn
• status: tạo thanh trạng thái.
• menubar: tạo thanh menu tại đỉnh của cửa sổ
• scrollbars: tạo thanh scroll bar
• resizable: cho phép user thay đổi kích th-ớc cửa sổ
• width: chỉ định chiều rộng cửa sổ theo đơn vị pixel
• height: chỉ định chiều cao cửa sổ theo đơn vị pixel
Ví dụ 1:
window.open( “plc.htm”, ”newWindow”, ”toolbar=yes, location=1,
directories=yes, status=yes, menubar=1, scroolbar=yes,
resizable=0, copyhistory=1, width=200, height=200”);
Ví dụ 2:
<HTML>
<HEAD>
<TITLE>WINDOWS</TITLE>
<SCRIPT>
<!--
function openWindow(url,name) {
popupWin = window.open(url, name, "scrollbars=yes,width=800,
heigth=200 ");
}
-->
</SCRIPT>
</HEAD>
<BODY>
<a
href="javascript:openWindow('../chuyende/plc.htm','Win')">PLC</a>,
<a
href="javascript:openWindow('../chuyende/suachuaw.htm','stoogeWin
')">Sua chua</a>,
<a
href="javascript:openWindow('../chuyende/tkweb.htm','stoogeWin')">
Thiet ke web</a>
</BODY>
</HTML>
Để đóng cửa sổ ta có thể dùng ph-ơng thức close()
Ví dụ:
<HTML>
<HEAD>
<TITLE>Close Example</TITLE>
</HEAD>
<BODY >
<A>
<IMG
BORDER="0"></A>
<A>Close This
Sample</A>
</BODY >
</HTML>
http://www.ebook.edu.vn 66
3.1.14 Sử dụng đối t-ợng string
String là một đối t-ợng của JavaScript, khi dùng đối t-ợng string chúng ta
không cần các phát biểu để tạo một instance (thể hiện) của đối t-ợng, bất kỳ lúc
nào ta đặt text giữahai dấu ngoặc kép và gán nó đến một biến hoặc một thuộc tính
thì ta đã tạo một đối t-ợng string.
a. Các thuộc tính của đối t-ợng string
Thuộc tính lengthtrả về số ký tự (chiều dài) của string.
b. Các ph-ơng thức (Methods) của đối t-ợng string
• anchor (nameAttribute)
• big()
• blink()
• bold()
• charAt(index)
• fixed()
• fontcolor(color)
• fontsize(size)
• indexOf(character,[fromIndex])
• italics()
• lastIndexOf(character,[fromIndex])
• link(URL)
• small()
• strike()
• sub()
• substring(startIndex,endIndex)
• sup()
• toLowerCase()
• toUpperCase()
3.2 VBScript
VBScript là một công nghệ của Microsoft yêu cầu phải có Microsoft Internet
Explorer. Tr-ớc khi bắt đầu học viết VBScript, chúng ta cần phải biết các khái niệm
cơ bản về: WWW, HTML và các kiến thức căn bản để xây dựng một trang web.
3.2.1 VBScript là gì?
VBScript là một ngôn ngữ kịch bản. Một ngôn ngữ script là một ngôn ngữ
lập trình nhẹ. VBScript là phiên bản nhẹ của ngôn ngữ lập trình Vusual Basic.
Khi VBScript đ-ợc chèn vào trong văn bản HTML, trình duyệt Internet sẽ
đọc văn bản HTML đó và dịch các đoạn mã VBScript. Các đoạn mã này đ-ợc thực
hiện hoặc là ngay lúc đó hoặc trong các sự kiện sau này.
3.2.2 Biến và phạm vi biến
Biến là một vùng chứa thông tin cần l-u trữ. Giá trị của biến có thể đ-ợc thay
đổi trong quá trình lập trình. Ta có thể làm việc với một biến thông qua tên của nó,
cũng nh-có thể thay đổi giá trị của biến đó.Trong VBScript, tất cả các biến đều
có kiểu là variant, và nó có thể l-u trữ bất kỳ dạng dữ liệu nào.
http://www.ebook.edu.vn 67
Quy tắc đặt tên biến: Bắt đầu bằng một chữ cái, không chứa dấu (.) và độ dài
không quá 255 ký tự. Chúng ta có thể khai báo biến với các từ khoá Dim, Public
hoặc Private.
Ví dụ d-ới đây khai báo một biến tên name và gán cho nó một giá trị:
dim name
name = giá trị
Ta cũng có thể khai báo biến bằng cáchsử dụng nó trong script của mình.
Ví dụ:
name = giá trị
Tuy vậy, cách khai báo này không đ-ợc t-ờng minh và không tốt cho ứng
dụng của chúng ta, vì sau đó trong ứng dụng của mình, chúng ta có thể vô tình viết
sai tên biến và có thể nhận đ-ợc kết quả không chính xác khi chạy ch-ơng trình.
Điều đó xảy ra là vì giả sử ta có một tên biến tên “name”, sau đó ta gọi tới biến đó
bằng một tên “nime” chẳng hạn, ch-ơng trình sẽ tự động sinh ra thêm 1 biến tên
“nime”. Để tránh xảy ra điều nhầm lẫn này, chúng ta nên sử dụng câu lệnh Option
Explicit. Khi sử dụng câu lênh này, tất cả các biến đều phải khai báo tr-ớc khi sử
dụng bởi các câu lệnh với từ khoá Dim, Public hoặc Private. Đặt câu lệnh Option
Explicit trên đầu của ch-ơng trình, nh-ví dụ sau:
Option Explicit
dim name
name = giá trị
Cách gán giá trị cho biến:
Ta có thể gán giá trị cho cho một biến nh-sau:
name = “Nguyễn Minh Ph-ợng”
i = 200 là thời gian sống của biến (Khoảng thời gian biến đó tồn tại đ-ợc gọi
là thời gian sống của nó). Khi khai báo một biến trong một thủ tục, biến đó chỉ
đ-ợc truy xuất tới trong phạm vi thủ tục đó. Khi thủ tục đó kết thúc, các biến đó
cũng bị huỷ. Những biến này đ-ợc gọi là biến cục bộ. Chúng ta có thể đặt các biến
cục bộ trùng tên nhau trong các thủ tục khác nhau, bởi vì mỗi biến chỉ đ-ợc nhận
biết bởi chính thủ tục trong đó chúng đ-ợc khai báo.
Nếu khai báo một biến bên ngoài một thủ tục, tất cả các thủ tục nằm trong
cùng trang đó đều có thể truy nhập tới biến đó. Thời gian sống của biến này bắt đầu
từ lúc nó đ-ợc khai báo và kết thúc khi trang web đ-ợc đóng lại.
Biến Array (mảng): Có những khi chúng ta muốn gán nhiều hơn 1 giá trị cho
một biến, khi đó ta khai báo một biến cóthể chứa một dãy dữ liệu. Biến này đ-ợc
gọi là biến mảng (array). Để khai báo một biến là biến array, chúng ta đặt dấu
ngoặc đơn ngay sau tên biến.
Ví dụ sau chúng ta khai báo một biến array gồm có 3 giá trị:
dim names(2)
Giá trị số trong dấu ngoặc là 2. Chỉ sốcủa biến array bắt đầu bởi 0 cho nên
biến này sẽ bao gồm 3 giá trị. Đây là một array có độ dài cố định. Ta gán giá trị
cho từng phần tử của array bằng cách sau:
names(0) = “Nguyễn Thanh Bình”
names(1)=”Nguyễn Minh Ph-ợng”
names(2)=”Hoàng Khánh H-ng”
http://www.ebook.edu.vn 68
T-ơng tự nh-vậy chúng ta có thể lấy giá trị của bất kỳ phần tử nào trong
array mà ta cần bằng cách sử dụng chỉ số t-ơng ứng của phần tử:
eng = names(0)
Chúng ta chỉ có thể khai báo nhiều nhấttới 60 chiều cho một array. Các
chiều đ-ợc khai báo cách nhau bởi dấu phẩy. Ví dụ sau khai báo một array bao
gồm 5 dòng và 7 cột:
dim table(4,6)
3.2.3 Các kiểu dữ liệu
a. Kiểu dữ liệu trong VBScript là gì?
VBScript chỉ có một kiểu dữ liệu tên làvariant. Kiểu variant là một kiểu dữ
liệu đặc biệt có thể chứa các loại thông tin khác nhau phụ thuộc vào cách sử dụng
chúng. Cũng vì nó là kiểu dữ liệu duy nhất trong VBScript cho nên tất cả các hàm
của VBScript đều trả về kiểu dữ liệu này.
Nói một cách đơn giản nhất, một biến variant có thể chứa thông tin là một số
hoặc một xâu. Biến variant này xử sự nh-một số khi nó đ-ợc sử dụng trong ngữ
cảnh số và nh-một xâu khi sử dụng nó trong ngữ cảnh xâu. Điều đó có nghĩa là
nếu ta làm việc với một dữ liệu trông giống kiểu số, VBScript sẽ cho rằng đó là một
số và thực hiện tất cả các công việc phù hợp nhất với một số. T-ơng tự nh-vậy, nếu
ta làm việc với dữ liệu là một xâu, VBScript coi đó là một xâu. Tất nhiên chúng ta
hoàn toàn có thể coi dữ liệu số là một xâu bằng cách đặt số đó trong cặp ngoặc kép
(“”).
b. Kiểu dữ liệu con của Variant – variant subtypes
Ngoài việc đơn giản là phân biệt số vàxâu, một variant có thể phân biệt đ-ợc
thông tin số theo cách khác. Chảng hạn chúng ta có thể có một dữ liệu số đại diện
cho Date/Time. Khi sử dụngnó cùng với một dữ liệu kiểu Date/Time khác thì kết
quả trả về luôn đ-ợc biểu diễn d-ới dạng Date/Time. Tất nhiênta có thể còn có một
loạt các dữ liệu dạng số với kích th-ớc khác nhau từ kiểu Boolean cho tới kiểu
floating – point. Các dạng thông tin khác nhau đó có thể đ-ợc l-u trong biến
variant gọi là các kiểu con (subtype). Phần lớn thời gian, chúng ta chỉ cần gán dữ
liệu của mình vào biến variant và biến này sẽ hoạt động theo cách xử lý dữ liệu
giống nh-chính dữ liệu mà nó chứa.
Bảng d-ới đây mô tả các kiểu dữ liệu con của variant:
Subtype Mô tả
Empty Variant ch-a đ-ợc gán giá trị ban đầu. Có giá trị 0 đối với các
biến kiểu số và xâu rỗng (“”) đối với biến xâu.
Null Variant không chứa dữ liệu
Boolean Có giá trị là True hoặc False
Byte Chứa số nguyên từ 0 tới 255.
Integer Chứa số nguyên từ-32,768 tới 32,767.
Currency -922,337,203,685,477.5808 tới 922,337,203,685,477.5807.
Long Chứa số nguyên từ -2,147,483,648 tới 2,147,483,647.
Single Chứa số single-precision, floating-point từ -1.402823E38 tới
-1.401298E-45 đối với giá trị âm, từ 1.401298E-45 tới
3.402823E38 đối với giá trị d-ơng.
http://www.ebook.edu.vn 69
Double Chứa số double-precision, floating-point -1.79769313486232E308 to -4.94065645841247E-324 đối với
giá trị âm, từ 4.94065645841247E-324 tới
1.79769313486232E308 đối với giá trị d-ơng.
Date (Time) Chứa một giá trị số đại diện cho ngày tính từ January 1, 100 tới
December 31, 9999.
String Chứa một xâu có độ dài bất kỳ dài nhất khoảng 2 tỷ ký tự
Object Chứa một Object
Error Chứa mã số lỗi
Chúng ta có thể dùng các hàm chuyển đổi kiểu dữ liệu để chuyển dữ liệu
giữa các kiểu dữ liệu con với nhau. Thêm vào đó, hàm VarType cho ta biết thông
tin về cách l-u trữ dữ liệu của mình trong biến Variant.
c. Các hàm trong VBScript:
D-ới đây liệt kê các hàm có sẵn trong VBScript. Các hàm này đ-ợc chia ra
thành các loại sau:
• Các hàm về thời gian
• Các hàm chuyển đổi kiểu dữ liệu
• Các hàm định dạng dữ liệu
• Các hàm toán học
• Các hàm về dãy
• Các hàm về xâu
• Các hàm khác
Các hàm về thời gian (Date/Time Functions)
Tên hàm Mô tả
Cdate Chuyển biểu thức có dạng date and time chuẩn sang dạng
Date
Date Trả về ngày giờ hệ thống
DateAdd Trả về ngày đ-ợc cộng thêm một khoảng thời gian
DateDiff Trả về giá trị số là khoảng thời gian giữa hai giá trị ngày.
DatePart Trả về phần xác định của ngày.
Day Trả về ngày hiện tại. Giá trị từ 1 tới 31.
FormatDateTime Trả về biểu thức đã đ-ợc định dạng theo kiểu date or time
Hour Trả về giá trị là một số chỉ giờ hiện hành trong ngày, có
giá trị từ 0 tới 23.
IsDate Trả về giá trị Boolean cho biết biểu thức có thể chuyển
sang dạng ngày tháng hay không.
Minute Trả về giá trị số là phút của giờ (có giá trị từ 0 tới 59)
Month Cho biết tháng hiện hành (Có giá trị từ 1 tới 12)
MonthName Trả về tên tháng
Now Cho biết ngày giờ hiện hành của hệ thống
Second Trả về số đại diện cho giây (Có giá trị từ 0 tới 59)
Time Trả về giờ hệ thống
Timer Trả về giá trị số giây tính từ 12:00 AM
Weekday Trả về số đại diện cho ngày trong tuần (Có giá trị từ 1tới 7)
http://www.ebook.edu.vn 70
WeekdayName Trả về tên ngày trong tuần
Year Trả về năm hiện hành
Các hàm chuyển kiểu dữ liệu (Conversion Functions)
Tên hàm Mô tả
Asc Chuyển ký tự đầu tiên của xâu sang mã ANSI.
CBool Chuyển dữ liệu kiểu variant sang kiểu subtype Boolean
CByte Chuyển dữ liệu từ kiểu variant sang kiểu subtype Byte
CCur Chuyển dữ liệu từ kiểu variant sang kiểu subtype Currency
CDate Chuyển dữ liệu từ biểu thứcdạng date/time sang kiểu subtype
Date/Time
CDbl Chuyển biểu thức từ kiểu variant sang kiểu subtype Double
Chr Chuyển mã ANSI sang ký tự
CInt Chuyển dữ liệu kiểu variant sang kiểu subtype Integer
CLng Chuyển dữ liệu kiểu variant sang kiểu subtype Long
CSng Chuyển dữ liệu kiểu variant sang kiểu subtype Single
CStr Chuyển dữ liệu kiểu variant sang kiểu subtype String
Các hàm định dạng dữ liệu (Format Functions)
Tên hàm Mô tả
FormatCurrency Trả về biểu thức đ-ợc định dạng kiểu nh-currency
FormatDateTime Trả về biểu thức đ-ợc định dạng kiểu date or time
FormatNumber Trả về biểu thức đ-ợc định dạng kiểu số.
FormatPercent Trả về biểu thức đ-ợc định dạng kiểu percentage
Các hàm toán học (Math Functions)
Tên hàm Mô tả
Abs Giá trị tuyệt đối của một số
Atn Trả về cotan của một số
Cos Giá trị cosine của một số (Góc)
Hex Cho giá trị hexadecimal của một số
Int Trả về phần nguyên của một số
Fix Trả về phần nguyên của một số
Log Logarit tự nhiên của một số
Oct Cho giá trị octal của một số
Rnd Cho một số ngẫu nhiên nhỏ hơn 1 và lớn hơn hoặc bằng 0
Sgn Trả về một số đại diện cho dấu của số
Sin Giá trị Sin của một số (Góc)
Sqr Bình ph-ơng của một số
Tan Giá trị Tang của một số (Góc)
Các hàm về array (Array Functions)
Tên hàm Mô tả
Array Trả về một variant chứa một array
IsArray Trả về giá trị Boolean cho biết biến đó có phải là một array hay
không.
Join Trả về một xâu chứa số các xâu con trong dãy
LBound Trả về cận d-ới của chiếu đ-ợc chỉ định của một array
http://www.ebook.edu.vn 71
Split Trả về một array 1 chiều chứa một số l-ợng phần tử đ-ợc chỉ định.
UBound Trả về cận trên của chiều đ-ợc chỉ định của array
Các hàm về xâu (String Functions)
Tên hàm Mô tả
InStr Trả về vị trí đầu tiên mà một xâu xuất hiện trong một xâu khác.
Tìm kiếm đ-ợc bắt đầu từ ký tự đầu tiên của xâu
InStrRev Trả về vị trí đầu tiên mà một xâu xuất hiện trong một xâu khác.
Tìm kiếm đ-ợc bắt đầu từ ký tự cuối cùng của xâu
LCase Chuyển tất cả các ký tự của một xâu thành chữ th-ờng
Left Trả về một xâu có độ dài đ-ợc chỉ định tính từ ký tự đầu tiên
Len Trả về độ dài của xâu
LTrim Xoá các ký tự trắng bên trái của xâu
RTrim Xoá các ký tự trắng bên phải của xâu
Trim Xoá các ký tự trắng ở cả hai phía của xâu
Mid Trả về một xâu có độ dài đ-ợc chỉ định và bắt đầu từ một vị trí
đ-ợc chỉ định của xâu nguồn
Replace Thay một phần của xâu bởimột xâu khác. Số các lần thay đ-ợc
chỉ định tr-ớc.
Right Trả về một xâu có độ dài đ-ợc chỉ định tính từ ký tự cuối cùng
Space Trả về một xâu chỉ gồm toàn dấu cách. Số l-ợng dấu cách đ-ợc
chỉ định
StrComp So sánh hai xâu vàtrả về một giá trị là kết quả của phép so sánh
String Trả về một xâu có đọ dài đ-ợc chỉ định và đ-ợc tạo ra bằng cách
lặp đi lặp lại một ký tự nào đó
StrReverse Trả về một xâu bằng cách quay ng-ợc một xâu có sẵn
UCase Chuyển tất cả các ký tự của 1 xâu thành chữ hoa
Các hàm khác (Other Functions)
Tên hàm Mô tả
CreateObject Tạo một Object có kiểu đ-ợc chỉ định
Eval Đánh giá một biểu thức và trả về một giá trị là kết quả của sự
đánh giá đó
InputBox Hiển thị một hộp thoại cho phép ng-ời sử dụng có thể điền
thông tin vào
IsEmpty Trả về một giá trị Boolean cho biết một biến đã đ-ợc gán giá
trị hay ch-a
IsNull Kiểm tra xem một biến có là Null (Không chứa dữ liệu)
không. Kết quả là một giá trị Boolean
IsNumeric Trả về một giá trị Boolean cho biết biểu thức đó có thể chuyển
thành dạng số không
MsgBox Hiển thị một hộp tin nhắn và chờ ng-ời sử dụng click vào một
nút lệnh, và trả về giá trị cho biết ng-ời sử dụng đã click nào
nút lệnh nào
Round Làm tròn một số
ScriptEngine Trả về tên của script đang dùng
http://www.ebook.edu.vn 72
TypeName Trả về tên kiểu dữ liệu con của biến
VarType Trả về giá trị của kiểu dữ liệu con của biến
d. Các toán tử và biểu thức
VBScript có một tập hợp lớn các loại toán tử, chia ra thành ba loại là các toán
tử số học, các toán tử so sánh và ghép nối (concatenation), và các toán tử logic.
Thứ tự -u tiên của các toán tử
Khi có nhiều toán tử cùng xuất hiện trong một biểu thức, từng phần của biểu
thức đ-ợc đánh giá và xử lý theo một trình tự gọi là thứ tự -u tiên. Ta có thể dùng
dấu ngoặc đơn để thay đổi thứ tự -u tiên và bắt một phần nào đó của biểu thức phải
đ-ợc thực hiện tr-ớc các phần khác. Các biểu thức bên trong dấu ngoặc đơn luôn
đ-ợc xử lý tr-ớc những biểu thức bên ngoài. Tất nhiên, nếu biểu thức trong ngoặc
chứa nhiều toán tử thì chúng cũng phải tuân theo thứ tự -u tiên chuẩn.
Khi các biểu thức chứa nhiều loại toántử khác nhau, các toán tử số học đ-ợc
xử lý tr-ớc, sau đó đến các toán tử so sánh rồi cuối cùng là các toán tử logic. Các
toán tử so sánh tất cả có cùng thứ tự -u tiên, tức là chúng sẽ đ-ợc xủa lý từ trái qua
phải theo thứ tự xuất hiện. Các toán tử số học và logic đ-ợc xử lý theo thứ tự sau:
Số học So sánh Logic
Mô tả Ký hiệu Mô tả Ký hiệu Mô tả Ký hiệu
Mũ hoá ^ So sánh bằng = Phủ nhận logic Not
Phép nhân * So sánh khác
nhau
<> Và And
Phép chia / Nhỏ hơn < Hoặc Or
Chia lấy phần
nguyên
\ Lớn hơn > Loại trừ Xor
Chia lấy số d- Mod Nhỏ hơn hoặc
bằng
<= So sánh bằng Eqv
Phép cộng + Lớn hơn hoặc
bằng >=
Phép trừ - So sánh Object
t-ơng đ-ơng Is
Ghép xâu &
Khi phép nhân và chia cùng xuất hiện trong một biểu thức, chúng đ-ợc xử lý
từ phải qua trái theo thứ tự xuất hiện. T-ơng tự nh-vậy đối với phép cộng và trừ.
Phép ghép xâu không thuộc nhóm toán tử số học nh-ng về thứ tự -u tiên nó
đứng sau các toán tử số học và tr-ớc các toán tử so sánh. Toán tử Is là một toán tử
so sánh việc tham chiếu Object. Nó không dùng để so sánh object hay giá trị của
chúng, nó chỉ cho biết xem hai tham chiếu object (object references) có loại hay
không.
e. Các cấu trúc điều khiển
Khi viết ch-ơng trình, nhiều khi cần thực hiện một hành động nào đó tuỳ
thuộc vào một số điều kiện, ta có thể dùng cấu trúc điều kiển để thực hiện điều này.
Trong VBScript có 3 dạng cấu trúc điều khiển:
Câu lệnh if ... then ... else:Sử dụng câu lệnh này khi cần lựa chọn một trong
điều kiện để thực hiện một trong hai tập hợp lệnh. Dùng câu lệnh này ta có thể:
• Thực hiện một tập hợp lệnh nào đó nếu điều kiên thoả mãn.
if i = 10 then msgbox “Hello”
Nếu muốn thực hiện nhiều hơn một câu lệnh khi điều kiện đ-ợc thoả mãn,
chúng ta cần viết từng câu lệnh trên một dòng lệnh khác nhau và kết thúc bởi từ
khoá “End If”.
if i = 10 then
msgbox “Hello”
i = i + 1
End if
• Lựa chọn một trong hai tập hợp lệnh đểthực hiện: Nếu muốn thực hiện
một tập hợp lệnh nào đó khi điều kiện đ-ợc thoả mãn và thực hiện một
tập hợp lệnh khác nếu điều kiện không thoả mãn, ta dùng nh-sau:
if i = 10 then
msgbox “Hello”
else
msgbox “Goodbye”
End if
Câu lệnh if ... then....elseif:Sử dụng câu lệnh này khi muốn lựa chọn một
trong nhiều tập hợp lệnh để thực hiện.
if then
msgbox "You are going to pay cash!"
elseif then
msgbox "You are going to pay with visa."
elseif then
msgbox "You are going topay with American Express."
else
msgbox "Unknown method of payment."
end If
Câu lệnh Select case:Sử dụng câu lệnh này khi muốn lựa chọn một trong
nhiều tập hợp lệnh để thực hiện.
select case payment
case "Cash"
msgbox "You are going to pay cash"
case "Visa"
msgbox "You are going to pay with visa"
case "AmEx"
msgbox "You are going topay with American Express"
case Else
msgbox "Unknown method of payment"
end select
Câu lệnh này làm việc nh-sau: Đầu tiên chúng ta có một biểu thức, th-ờng
http://www.ebook.edu.vn 74
là một biến, cần đ-ợc đánh giá giá trị. Giá trị của biểu thức này đ-ợc so sánh với
từng giá trị trong cấu trúc Case. Nếu chúng bằng nhau, tập hợp các lệnh t-ơng ứng
với giá trị Case đó đ-ợc thực hiện.
f. Các cấu trúc lặp
Câu lệnh For...Next: Lặp lại việc thực hiện một tập hợp các câu lệnh một số
xác định lần. ta có thể sử dụng một biến đếm tăng dần hoặc giảm dần sau mỗi lần
thực hiện vòng lặp.
Cú pháp:
For i = 1 to 10 step 2
Các lệnh ở đây
Next
Từ khoá step chỉ b-ớc nhảy sau mỗi lần thực hiện các câu lệnh trong vòng
lặp. Nếu dùng vòng lặp giảm dần thì giá trị của step cần đặt là số âm.
Giá trị ngầm định là 1.
Từ khoá Exit For dùng để nhảy ra khỏi vòng lặp.
Vòng lặp với For Each... Next: Vòng lặp này thực hiện một tập hợp lệnh
đối với mỗi phần tử trong tập hợp, hoặc với mỗi phần tử trong một dãy. Câu lệnh
này thực hiện không khác nguyên tắc của vòng For...Next, chỉ khác ở chỗ ta không
cần chỉ ra số l-ợng lần muốn thực hiện vòng lặp.
dim names(2)
names(0)="Tove"
names(1)="Jani"
names(2)="Hege"
For Each x in names
document.write(x & "<br />")
Next
Cấu trúc Do ... Loop:
• Từ khoá While
Cấu trúc này dùng để thực hiện một tập hợp lệnh khi không biết tr-ớc số lần
cần thực hiện. Vòng lặp sẽ thực hiện khi điều kiện While vẫn còn đ-ợc thoã mãn.
Sử dụng từ khoá While để kiểm tra điều kiện trong cấu trúc Do...Loop.
Do While i>10
some code
Loop
Nếu i = 9 thì các câu lệnh trong cấu trúc này không đ-ợc thực hiện lần nào.
Nh-ng nếu thay đổi đoạn mã trên nh-sau:
Do
some code
Loop While i>10
Thì các câu lệnh trong Do...Loop đ-ợc thực hiện ít nhất một lần ngay cả khi
giá trị của i nhỏ hơn 10.
• Từ khoá Until
Lặp lại việc thực hiện các lệnh cho tới khi điều kiện thoả mãn bằng việc sử
http://www.ebook.edu.vn 75
dụng từ khoá Until.
Cú pháp:
Do Until i=10
some code
Loop
Nếu i = 10, các câu lệnh bên trong vòng lặp không đ-ợc thực hiện lần nào.
Do
some code
Loop Until i=10
Các câu lệnh bên trong vòng lặp đ-ợc thực hiện ít nhất một lần trong tr-ờng
hợp ta kiểm tra điều kiện sau.
• Từ khoá Exit Do
Thoát ra khỏi Do...Loop: Dùng lệnh Exit Do để thoát rakhỏi vòng lặp
Do...Loop:
Do Until i=10
i=i-1
If i<10 Then Exit Do
Loop
Các câu lệnh trong vòng lặp đ-ợc thực hiện khi khác 10, và khi i lớn hơn 10.
3.3 Câu hỏi và bài tập ch-ơng 3
3.3.1 Câu hỏi ôn tập
Câu 1: Khái niệm, đặc tính và cách thức nhúng JavaScript vào HTML.
Câu 2: Các kiểu dữ liệu trong JavaScript?
Câu 3: Các sự kiện trong JavaScript?
Câu 4: Khái niệm, cách thức nhúng VBScript vào tài liệu HTML.
Câu 5: Biến, cách thức đặt tên biến và phạm vi biến trong VBScript?
Câu 6: Các kiểu dữ liệu vàcác hàm trong VBScript?
3.3.2 Bài tập lập trình với các ngôn ngữ kịch bản
Bài 1: Tạo 2 nút bấm (OK và Cancel), thủ tục xử lý sự kiện khi nhấn nút OK
đ-ợc viết bằng VBScript và hàm sử lý sự kiện khi nhấn nút Cancel đ-ợc viết bằng
JavaScript.
Bài 2: Sử dụng JavaScript và VBScript lần l-ợt viết ch-ơng trình kiểm tra
tính hợp lệ của dữ liệu nhập từ form. Nếu thiếu thì thông báo cho ng-ời dùng biết,
ng-ợc lại thì thông báo “thông tin đac nhập đầy đủ”
Bài 3: Thiết kế form nhập liệu bao gồm các textbox: Họ, tên, quốc tịch
(listbox), điện thoại, địa chỉ, giới tính (radiobox), ngày tháng năm sinh (ngày,
tháng là listbox), nghề nghiệp (listbox),tên đăng nhập, mật khẩu, nhập lại mật
khẩu. Khi nhấn nút “Chấp nhận” thì kiểm tra tính đầy đủ và hợp lệ của dữ liệu, Nếu
nhấn “Từ chối” thì reset lại tất cả các hộp nhập dữ liệu. Thực hiện bằng cả
VBScript và JavaScript.
Bài 4: Thiết kế một form mô phỏng trang web đăng ký mail của Yahoo, sau
khi nhấn Submit thì kiểm tra tính hợp lệ vàđầy đủ của dữ liệu. Sử dụng cả VBScript
và JavaScript để kiểm tra.
http://www.ebook.edu.vn 76
Ch-ơng 4
Lập trình Web động với công nghệ ASP
4.1 Một số khái niệm cơ bản về ASP
4.1.1 Khái niệm Web động
Nh-đã biết ngôn ngữ đánh dấu siêu văn bản HTML là công cụ mô tả trang
Web trên Internet. Khi trình duyệt yêu cầu một trang HTML, Web Server nhận yêu
cầu và gửi trả lại file HTML đ-ợc yêu cầu. Trình duyệt sẽ trình diễn trang HTML
nhận đ-ợc.
Nói chung các trang HTML là tĩnh về mặt nội dung. Mặc dù trình duyệt có
thể xử lý các ngôn ngữ kịch bản nh-VBScript hay Jscript nếu nh-ng-ời ta cài đặt
các máy ảo tại client để tạo ra một hiệu quả động nào đó với các t-ơng tác hai
chiều. Tuy nhiên t-ơng tác này rất hạn chế nếu nh-dữ liệu cần sử dụng đặt tại
server chứ không phải tại client.
Trên thực tế có nhu cầu tra cứu thông tin theo yêu cầu. Ví dụ một siêu thị
điện tử, giới thiệu các mặt hàng trên trang Web, và thông tin về các mặt hàng đều
đ-ợc đ-a lên đầy đủ. Nếu trang Web này là tĩnh đ-ợc chuẩn bị tr-ớc thì ta không
thể lọc ra những thông tin mà mình cần đ-ợc mà phải duyệt cho tới khi gặp đ-ợc
mặt hàng mà mình quan tâm, nghĩa là phải đợi để thông tin đ-ợc chuyển về đầy đủ.
Vậy nhu cầu về một trang Web có thông tin đ-ợc chọn lọc theo yêu cầu từ Browse
ra đời. Các trang Web này đ-ợc gọi là trang Web động. Nói một cách đơn giản là
các trang Web động là các trang Web không tồn tại sẵn mà chỉ đ-ợc tạo ra theo
yêu cầu của ng-ời tra cứu. Trong tr-ờng hợp này CSDL Web không phải là tất cả
mà còn các CSDL kiểu khác giúp tạo nên các trang Web. Chính vì thế cần đ-a vào
các trang HTML khả năng tạo Web động d-ới dạng các dòng lệnh.
Microsoft quản lý các trang Web bởi IIS (Internet Information Server) trên
WebServer. Nh-ng IIS không tự tính toán đ-ợc các dòng lệnh ở phía Server để tạo
các trang Web động nên cần có thêm các thành phần khác.
Hiện nay có một số môi tr-ờng để tạo các trang Web động, có thể kể đến
nh-: lập trình trên CGI, ASP, PHP, Java, JSP….
4.1.2 ASP là gì?
ASP (Active Server Page) là một thành phần mở rộng của IIS. Khi cài đặt,
ASP sinh ra các bộ xử lý ảo đối với ngôn ngữ kịch bản (script engine) tại server để
IIS có thể xử lý các mã script mà các mã này có thể viết đan xen trong các trang
HTML. Khi Client gọi đến một file .asp trên Web Server, Web Server lập tức gọi
đến Script engine để xử lý. Script engine sẽ thực hiện các lệnh script để biến trang
ASP thành trang HTML rồi gửi lại Client. Chú ý rằng quá trình này thực hiện tại
server chứ không phải tại Client. Vì vậy chúng ta không phải quan tâm tới việc
browser xử lý các trang Web nh-thế nào. Nh-vậy thực sự quá trình này đ-ợc thực
hiện theo mô hình Client-Server.
ASP là công nghệ Web Server mới của Microsoft, nó đ-ợc thiết kế để giúp
ng-ời phát triển ứng dụng trên Web xây dựng các trang Web ứng dụng nhanh
chóng và dễ dàng. ASP là một phần tích hợp của công nghệ cơ sở Active (Active
Platform), là hạt nhân trong chiến l-ợc internet của Microsoft. Active Platform là
một tập hợp các ngôn ngữ, các chuẩn và các dịch vụ có thể đ-ợc sử dụng để phát
http://www.ebook.edu.vn 77
triển cả ứng dụng Active Desktop(bản Client) và Active Server (bản Server) trong
mô hình CSDL tính toán Client / Server. Mô hình Active Platform giúp cho ng-ời
phát triển ứng dụng xây dựng ứng dụng hiệu quả về giá thành, mở rộng khả năng
cảu các ứng dụng chạy trên Server cũng nh-chạy trên Client và nâng cao kỹ năng
phát triển ứng dụng của họ. Đồng thời, nó cũng làm việc chuyển đổi từ ứng dụng
Desktop sang ứng dụng Client/Server đầy đủ, dễ dàng.
4.1.3 Scripting?
Scripting là một đoạn ch-ơng trình mà chúng ta chènvào các trang HTML
để tạo tính “động” cho nó. Scripting dùng ngôn ngữ, cú pháp và cách thực hiện
riêng. Tuy nhiên, có một vấn đề nảy sinhở đây: Mỗi một hãng cung cấp lại định
nghĩa một ngôn ngữ script khác nhau. Microsoft phát triển Visual Basic Script
(VBScript), Sun Microsystem và Nescape pháttriển JavaScript (JScript) và một số
hãng khác hỗ trợ những ngôn ngữ nh-: Perl, Python, Awk ... .
a. Scripting trên Client:
Scripting trên Client có thể đ-ợc chèn vào trang HTML bằng cặp tags
<Script> ... </Script>.
Để xác định ngôn ngữ Script ta dùng thuộc tính LANGUAGE.
Ví dụ sau sẽ minh họa sựkiện xảy ra khi ng-ời dùng nhấn vào một nút. Chức
năng của nó đ-ợc chỉ ra bằng thuộc tính ONCLICK. Scripting trên Client có thể
làm việc trên bất kì máy chủ nào hỗ trợ ngôn ngữ của scripting .
Ví dụ: Dùng Scripting trên Client.
<HTML>
<HEAD>
<TITLE> Scripting </TITLE>
<SCRIPT LANGUAGE=”VBSCRIPT”>
sub vbs()
alert(“This is VBScript”)
end sub
</SCRIPT>
<SCRIPT LANGUAGE=”JAVASCRIPT”>
function js(){
alert(“This is JavaScript”)
}
</SCRIPT>
</HEAD>
<BODY>
Select button:
<INPUT TYPE=“button” NAME=“vbs” VALUE=“VBScript”
ONCLICK=“vbs()”>
<INPUT TYPE= “button” NAME= “js”VALUE= “JavaScript” ONCLICK=
“js()”>
</BODY>
</HTML>
http://www.ebook.edu.vn 78
Nhấn vào một nút, ch-ơng trình phù hợp sẽ đ-ợc chạy :
Hình 4.1 Hoạt động của VBScript và JavaScript
b. Scripting trên Server:
ASP sử dụng Scripting trên Server để tự động tạo ra những trang trả lời . Nội
dung sinh ra dựa trên những thông số của User đ-ợc gửi tới cùng yêu cầu và sự t--ơng tác giữa các đối t-ợng khác nhau . Ngoài ra chúng ta còn có thể sử dụng một
số Object và Component do ASP cung cấp. Các Object làm đơn giản hoá một số
công việc trên Server.
Scripting trên Server đ-ợc chèn vào một file ASP bằng cách sử dụng cặp tags
<SCRIPT> ... </SCRIPT> hoặc <% và %> . Để phân biệt Scripting đ-ợc viết trên
Client hay trên Server ta sử dụng thuộc tính RUNAT =“SERVER” .
Đối với hầu hết các browser thì ngôn ngữScript mặc định làJavaScript. Bởi
vậy, nếu chúng ta viết các mã lệnh bằng VBScript thì chúng ta phải khai báo với
browse trớc khi sử dụng :
<SCRIPT LANGUAGE= “VBSCRIPT”>
Ng-ợc lại với browser, ngôn ngữ script mặc định của ASP là VBScript. Nếu
chúng ta dùng JavaScript thì khai báo lại nh sau (chú ý thuộc tính RUNAT):
<SCRIPT LANGUAGE=“JCRIPT” RUNAT=“SERVER”>
Tùy theo khả năng và sở thích, chúng ta có thể sử dụng một trong hai ngôn
ngữ trên để lập trình. Tuy nhiên, có một chú ý quan trọng là hiện nay, JScript
(ECMA Script) là ngôn ngữ Scripting chuẩn đ-ợc Hiệp hội sản xuất máy tính Châu
Âu (European Computer Manufactury Association) công nhận.
4.1.4 Tạo và xem một file ASP
Chúng ta sử dụng những công cụ của Microsoft nh-: Microsoft Frontpage,
Microsoft’s Visual InterDevđể tạo một file ASP .
Để xem một file ASP, chúng takhông thể gửi nó đến Browser nh-một trang
http://www.ebook.edu.vn 79
HTML bởi vì Browser không nhận biết đ-ợc các file ASP. Lý do là các file này cần
phải đ-ợc thông dịch trên Server tr-óc khi gửi ra Browser.
Chúng ta có thể sử dụng IE hoặc Nescape Navigator để xem kết quả của các
file ASP nh-ng chúng ta cần chắc chắn rằng Servermà chúng ta xử lý các mã có
cài đặt ASP và đang chạy IIS hoặc Personal Web Server (PWS).
Trang ASP là một dạng text có kiểulà .asp, có cấu trúc gần giống nh-file
HTML. Tất cả các thẻ có trong HTML thì đều dùng đ-ợc trong ASP. Nh-ng ngoài
các thẻ thông th-ờng của HTML, trong file asp còn có thể viết các thẻ khác nữa để
thể hiện các dòng lệnh của Script để làm việc với dữ liệu có sẵn hay có thể tính
toán ngay bên trong nh-là một ngôn ngữ lập trình thực sự.
Cơ chế hoạt động của ASP nh-sau:
Client sử dụng một Web Browser gửi yêu cầu HTTP tới một Server chạy
Microsoft Internet Information Server (IIS). Sau khi nhận biết đó làyêu cầu cần xử
lý của trang ASP, IIS chuyển yêu cầu này tới ASP engine, tại đây nội dung file .asp
đ-ợc xử lý, các mã HTML đ-ợc để nguyên còn các Script đ-ợc tính dựa theo các
yêu cầu và đ-ợc chuyển đổi thành các mã HTML. Nếu trong các Script có các câu
lệnh gọi dữ liệu, nó sẽ liên kết tới Database Server và lấy các dữ liệu theo yêu cầu.
Sau đó, các kết quả của việc thực hiện các Script (có thể là HTML tĩnh hoặc động)
đ-ợc gửi trả lại Client Browser.
Xét một ví dụ để làm rõ cơ chế này:
<HTML>
<HEAD>
<TITLE>Example</TITLE>
</HEAD>
<BODY>
<% For i=5 to 7%>
<FONT SIZE=<%=i%>>Chào bạn!<BR></FONT>
<% Next %>
</BODY>
</HTML>
Kết quả là trình duyệt sẽ hiển thị 3 dòng Chào bạn! với kích th-ớc tăng dần
nh-sau
Chào bạn!
Chào bạn!
Chào bạn!
Trong ví dụ này chúng ta mới đề cập đến nguyên lý làm việc của ASP mà
ch-a nói đến cơ chế tạo Web động tức là cách tạo các trang Web thay đổi theo
thông tin t-ơng tác mà ng-ời sử dụng cung cấp. Trong ví dụ ta sẽ làm việc nh-sau:
Tạo một trang Web có một form để ng-ời sử dụng nhập vào họ, tên và giới
tính qua Textbox và option. Ng-ời sử dụng cũng đánh vào một số tự nhiên. Khi
nhận đ-ợc, ASP sẽ gửi lại một trang Web với một lời chào phù hợp với giới tính và
tên ng-ời đã đ-ợc cung cấp đồng thời cho ra tất cả các -ớc số của số này.
Sau đây là đoạn mã của hai trang ASP thực hiện hiệu ứng này. Có một số câu
lệnh script có thể còn lạ nh-ng ý nghĩa hoàn toàn rõ ràng.
http://www.ebook.edu.vn 80
<HTML>
<HEAD>
<TITLE>Example</TITLE>
</HEAD>
<BODY>
<P>Vi du ve form de trao doi thong tin theo phuong thuc POST</P>
<FORM>
<P> Ho dem: <input type ="text" size=20></P>
<P>Ten:<input type ="text" size=20></P>
<P> Gioi tinh: Nam <input checked
name="Gioitinh" size=20>
Nu <input type ="radio" value ="Nu" size=20></P>
<P>Cho so n <input type ="Text" size=8></P>
<P><input value ="Gui di">
<input></P>
</FORM>
</BODY>
</HTML>
Hình 4.2 Form sử dụng ASP
Đây là nội dung tệp Chao.asp mô tảứng xử khi ta bấm nút Gửi đi t-ơng ứng
với hoạt động Submit của Form
<HTML>
<HEAD>
<TITLE>Example</TITLE>
http://www.ebook.edu.vn 81
</HEAD>
<BODY>
<% ho=request.Form("hodem")
ten=request.Form("ten")
so=request.Form("so")
gioitinh=request.form("gioitinh")
if then
gioitinh="Ong"
else
gioitinh="Ba"
end if
response.Write "Xin chao " & gioitinh & " " & ho &" " & ten &" <br>"
response.Write "Day la ket qua tinh " & "<br>"
for i=1 to so-1
if so mod i =0 then
response.Write i & "<br>"
end if
next
%>
</BODY>
</HTML>
4.1.5 Server-side Includes:
Server-side Includes (SSI) là một thuật ngữ đ-ợc sử dụng để mô tả cách thức
các yếu tố khác nhau đ-ợc chèn vào trang Web
a. Gắn những file text vào một trang với #include:
Chúng ta có thể gắn file text GetLastDay.txt (vốn là một file ASP, đ-ợc save
với tên trên, có function có chức năng lấy lại ngày cuối cùng trong một tháng) vào
một trang Web bằng cách thêm câu lệnh trên vào trang và gọi chức năng:
<!-- #include file=”GetLastDay.txt” -->
...
intLastDayAugust = GetLastDay(datAugust) ‘ chức năng chúng ta gắn vào
...
Nếu muốn gắn Script từ các file khác, file này phải chứa những phần Script
hoàn chỉnh . Nói một cách khác, nó phảicó đủ những tag <SCRIPT> ... </SCRIPT>
hoặc <% ... %>.
b. Địa chỉ vật lý, địa chỉ ảo của file:
#include cho phép chúng ta chỉ đến một file bằng đờng dẫn vật lý hoặc đờng
dẫn ảo.Ví dụ file Mytext.txt nằm trong th mục c:\TextFile và cũng có bí danh
(alias) là /Text, ta có thể thamkhảo tới nó bằng những cách sau:
<!-- #include file=”C:\TextFile\MyFile.txt” --> ‘ đ-ờng dẫn vật lý
<!-- #include file=”/Text/MyFile.txt” --> ‘ đ-ờng dẫn ảo
http://www.ebook.edu.vn 82
4.2 Ưu điểm của việc sử dụng ASP tạo Web động
4.2.1 Đơn giản, dễ học và hiệu quả:
Học và phát triển ASP là rất dễ dàng. Ta có thể sử dụng ASP để xây dựng
một Web site có khả năng t-ơng tác cao. Vì các ngôn ngữ kịch bản nh-VBScript,
Jscript đ-ợc tích hợp trong ASP nên rất tiện cho ng-ời phát triển đã biết ngôn ngữ
VB, Java hay C++, còn đối với ng-ời ch-a biết thì việc học nó cũng dễ dàng.
Các ứng dụng ASP không cần có trình biên dịch. Trong một vài công nghệ
khác nh-CGI, để phát triển các trang Web động cần phải có một trình biên dịch để
dịch thành một ch-ơng trình có thể chạy đ-ợc sử dụng các môi tr-ờng phát triển
ứng dụng truyền thống nh-Visual C++. Sau khi ứng dụng đ-ợc dịch, nó sẽ đ-ợc
copy vào th-mục CGI của Web Server. Chỉ cần có một chút sửa đổi ch-ơng trình
thì ta phải dịch lại mã nguồn của ch-ơng trình và sau đó lại phải copy đè lên phiên
bản tr-ớc của file chạy. ASP giải quyết vấn đềnày bằng cách cung cấp các cách tạo
lập trang Web một cách trực tiếp và dễ dàn hơn theo kiểu thông dịch(interpreter).
Sau khi xây dựng xong một ứng dụng Web bằng ASP, takhông cần phải dịch
chùng mà chỉ cần l-u giữ vào một file có kiểu là .aspvà các ASP sẽ xử lý khi file
này đ-ợc gọi đến.
Ngoài các thành phần ASP sẵn có giúp chúng ta xây dựng rất nhiều ứng dụng
động khác, ASP cũng cho phép ta tự tạo racác thành phần ASP của riêng mình.
4.2.2 Bảo mật đ-ợc mã:
Một điểm bất lợi trong việc sử dụng ngôn ngữ kịch bản Client là phơi bày tất
cả các thông tin và thuật giải của bài toán. Nếu một bài toán sử dụng ngôn ngữ kịch
bản tại Client nh-VBSCript thì bất kỳ ai nhìn vào mã nguồn của trang Web đều có
thể thấy đ-ợc thuật toán của nó.
Với ASP tất cả các Script đ-ợc thực hiện trên Servervà chỉ có kết quả ra d-ới
dạng HTML đ-ợc gửi về Browser nên nếu ng-ời dùng muốn xem mã nguồn của
trang Web thì họ chỉ xem đ-ợc mã HTML chứ không xem đ-ợc mã Script đã tạo
nên trang Web đó. Nh-vậy nếu sử dụng ASP thì NSD không thể biết đ-ợc thuật
toán của nhà phát triển vì các mã ASP đ-ợc thực hiện trên Server. ASP bảo vệ sự sở
hữu về thông tin và thuật toán.
4.2.3 Bảo trì dễ dàng:
Môi tr-ờng phát triển ASP giúp nâng cao hiệu quả sử dụng của các thiết bị
sẵn có. Môi tr-ờng phát triển ASP giúp cho ng-ời phát triển sử dụng một cách dễ
dàng và có hiệu quả các kỹ năng sẵn có. ASP cung cấp một cơ cấu thiết lập các
trang Web phức tạp sử dụng ngôn ngữ kịch bản quen thuộc nh-VBScript,
Jscript/JavaScript hay Perl.
Đối với nhiều phần mềm Client/Server khác, ngoài phần đ-ợc viết trên
Server, còn cần phần viết trên Client. Nh-vậy độ phức tập và tốn kém về mặt lập
trình sẽ tăng lên. Khi viết bằng ASP thì chỉ cần có trình duyệt Web tại máy Client,
sau đó nối đến máy chủ, nh-thế việc trên Client không còn gì phả quan tâm. Mỗi
khi cần sửa chữa hoặc nâng cấp không cần phải làm gì với bản Client.
Thông qua các câu lệnh Script, ta có thể kết nối đến với một CSDL tại một
Database Server. Để làm việc trên CSDL này, ta có thể nhúng ngôn ngữ truy vấn
SQL. Thông qua đó việc lọc dữ liệu đơn giản, công việc lọc dữ liệu đ-ợc tiến hành
trên Server nên tránh đ-ợc ách tắc đ-ờng truyền.
http://www.ebook.edu.vn 83
4.3 Cài đặt IIS và tạo th-mục ảo cho ứng dụng
4.3.1 1. Cài đặt IIS
Internet Information Services mặc định không đ-ợc cài đặt trên hệ điều hành
Windows XP Professional. Ta có thể gỡ bỏ hoặc thêm các components bằng việc sử
dụng ch-ơng trình ứng dụng Add/Remove Programs trong tiện ích Control Panel.
Các b-ớc cài đặt tuần tự nh-sau:
• Click Start, click Control Panel, và double-click Add/Remove
Programs.
• Trong cột bên trái của hộp thoại Add/Remove Programsdialog box,
click Add/Remove Windows Components.
• Khi cửa sổ Windows ComponentsWizard xuất hiện, click Next.
• Trong danh sách các thành phần của Windows( Windows Components),
chọn IIS.
• Click Next, và làm theo các chỉ dẫn của Wizard.
4.3.2 Tạo th-mục ảo:
Chúng ta có thể tạo các th-mục ảo bên d-ới ứng dụng Default Web site.
Thông th-ờng một ứng dụng Web đ-ợc đặt trong một th-mục ảo và đ-ợc tham
chiếu đến thông qua địa chỉ URL.
Chọn Internet Information Service:
Hình 4.3 Tạo th-mục ảo trong IIS
Nhấn chuột phải vào Default Web Site, chọn New/Vitual Directory, cửa sổ
trợ giúp Wizard sẽ hiện ra nh-sau:
http://www.ebook.edu.vn 84
Hình 4.4 Nhập bí danh (Alias) cho the mục ảo
Trong ô nhập liệu Alias, nhập vào tên bí danh cho th-mục ảo, chẳng hạn
example. Kích vào nút Next để đến b-ớc kế tiếp.
Hình 4.5 Chọn đ-ờng dẫn vật lý cho th-mục ảo
Sau khi chọn đ-ờng dẫn vật lý cho th-mục ảo, ta tiến hành thiết lập quyền
truy cập cho th-mục ảo. Hai quyền Read và Run Script là cần thiết để trang ASP
có thể truy xuất đ-ợc, ngoài ra ta có thể thiết lập các quyền khác cho ng-ời quản trị
site (Administrator).
http://www.ebook.edu.vn 85
Hình 4.6 Thiết lập quyền truy cập cho th-mục ảo.
4.4 Cấu trúc và các dòng lệnh cơ bản của ASP
4.4.1 Các thành phần đ-ợc dùng trong trang ASP
File ASP là một file d-ới dạng Text, ta có thể sử dụng bất cứ trình soạn thảo
văn bản d-ới dạng text only để soạn thảo ra file ASP. File ASP có phần mở rộng là
.asp . Trong file ASP có thể có:
• Các mã HTML.
• Các ký hiệu phấn cách Script.
• Các mã Script.
• Các thànhh phần ActiveX.
• Các đối t-ợng ASP.
Điểm khác biệt cơ bản giữa file ASP với file HTML là sự có mặt các dấu
phân chách các mã Script với các mã HTML. Trong file ASP nếu ta viết h-ớng dẫn
<%<lệnh>%> thì ASP hiểu rằng lệnh bên trong hai dấu <% và %> là một lệnh
Script. Nh-đã nói ở trên, các lệnh Script có thể là VBScript hay Jscript.
4.4.2 Biến trong ASP
Biến đ-ợc cho bằng một tên gọi nào đó (quy cách giống nh-biến dùng trong
Visual Basic) – có thể tra cứu các tài liệu của VB để biết thêm nguyên tắc đặt tên
biến. Khi sử dụng biến trong Script, ta không cần phải khai báo tr-ớc mà có thể sử
dụng trực tiếp. Các biến trong ASP không có kiểu, kiểu của nó sẽ đ-ợc xác định
một cách tự động khi có lệnh gán giá trị vào biến. Nếu có khai báo biến thì cú pháp
nh-sau: Dim tên_biến
4.4.3 Các lệnh cơ bản của ASP
a. Lệnh gán:
Cú pháp: <%<biến>=[giá trị]%>
Lệnh này sẽ nạp giá trị vào biến
b. Lệnh đ-a ra màn hình giá trị của biến:
Cú pháp: <%=<biến>%>
Khi xử lý lệnh này, ASP chuyển đoạn mã ngữ trên thành một văn bản với nội
dung chính là lệnh gán giá trị của biến. Khi trình duyệt xử lý nó sẽ hiển thị giá trị
này ra màn hình.
c. Các cấu trúc điều khiển:
Câu lệnh If-then-else – end if
<% if <điều kiện> then <các câu lệnh> [else <các câu lệnh khác>]%>
Ví dụ kiểm tra thời gian để hiển thị câu “Bây giờ là buổi sáng” hay “Bây giờ
là buổi chiều”
<% if time<=#12:00:00 AM# then
x=“Bây giờ là buổi sáng”
else
x=“Bây giờ là buổi chiều”
end if
%>
<%=x%>
Cấu trúc lựa chọn Select Case
Cú pháp:
Select case biến
Case <tậpgiátrị1>
<dãy câu lệnh 1>
Case <tậpgiátrị2>
<dãy câu lệnh 2>
…….
Case <tậpgiátrị n>
<dãy câu lệnh n>
Case else
<dãy câu lệnh n+1>
end select
Ví dụ:
<%
bien=5
select case bien
case 1,2,3
Response.Write ("chon 1")
case 2,3,4
Response.Write "chon 2"
case else
Response.write "chon 3"
end select
%>
=> Kết quả: Chon 3
4.4.4 Vòng lặp For:
Cú pháp:
<%For <biến đếm>=<giá trị đầu> to <giá trị cuối>%>
[Các lệnh khác]
<%Next [biến đếm]%>
Ví dụ:
<%for i=5 to 7 %>
<font size =<%=i%>>Chào bạn!<br></font>
<% Next %>
4.4.5 Câu lệnh lặp không xác định:
Cú pháp:
while <điều kiện>
<thực hiện công việc>
Wend
Do while <điều kiện>
Loop
Do
<công việc>
Loop While <điều kiện>
Ví dụ:
<%
i=1
do
i=i+1
Response.Write i
loop while i<=10
%>
4.5 Xây dựng các hàm và thủ tục trong ASP:
Ta có thể sử dụng các ngôn ngữ Script để xây dựng các hàm và thủ tục trong
file ASP. Tr-ớc khi viết một hàm và thủ tục bằng ngôn ngữ gì ta phải thông báo
cho ASP biết bằng thẻ Script nh-đã biết.
Cấu trúc một hàm trong ASP có dạng sau:
<SCRIPT RUNAT =SERVER LANGUAGE=”LANGUAGENAME”>
‘Hàm:
Function <FunctionName> (Biến)
http://www.ebook.edu.vn 88
Các dòng lệnh Script
End Function
‘Thủ tục:
Sub <SubName> (Biến)
Các dòng lệnh Script
End Sub
</SCRIPT>
Đối với hàm thì trong thân của hàm cần có một lệnh gán giá trị tính đ-ợc cho
một biến có thên trùng với tên hàm.
Cách gọi hàm hoàn toàn t-ơng tự nh-cách lấy giá trị từ một biến.
Cách gọi thủ tục: Call SubName hoặc SubName
Ví dụ ta có hàm sau:
<%Function Calculate(A, B, Op)
Select Case Op
Case “+”
Calculate = A+B
Case “-”
Calculate = A-B
Case “*”
Calculate = A*B
Case “/”
Calculate = A/B
End Select
End Function
Response.write Calculate(2, 3, “+”)
Response.write Calculate(2, 3, “-)
%>
Chú ý: Có thể sử dụng <!--#include file|virtual=”file_name”--> để sử dụng
lại các hàm và thủ tục đã đ-ợc xây dựng trong một file nào đó.
4.6 Sử dụng các đối t-ợng của ASP để trao đổi thông tin giữa Client và Server.
4.6.1 Giới thiệu các đối t-ợng chính của ASP:
a. Các đối t-ợng chính:
T-ơng tự nh-trong các ngôn ngữ lập trình h-ớng đối t-ợng, ASP cho phép
ng-ời lập trình tạo ra các đối t-ợng, các lớp theo mục đíchsử dụng riêng. ASP cũng
cung cấp sẵn có một số đối t-ợng hay đ-ợc sử dụng. Đó là 5 đối t-ợng sau:
Các đối t-ợng ýnghĩa
Application Chia sẻ thông tin giữa các ng-ời dùng trong một ứng dụng
Session L-u giữ các thông tin duy nhất vềphiên làm việc hiện thời
của một ng-ời sử dụng cụ thể
Server Cho phép truy cập tới máy chủ
http://www.ebook.edu.vn 89
Request Lấy thông tin từ phía ng-ời dùng
Response Gửi thông tin tới ng-ời dùng
Mỗi đối t-ợng đều có các ph-ơng thức đi kèm. Cú pháp chung để gửi thông
điệp cho các đối t-ợng hoàn toàn bình th-ờng:
Object.Method parameters.
ởđây parameters có thể là biến, dữ liệu, chuỗi hoặc URL tuỳ thuộc vào
ph-ơng thức Method.
Ngoài ra còn có đối t-ợng ObjectContext: để chấp nhận hoặc từ chối một
giao tác. Đối t-ợng này đ-ợc quản lý bởi MTS và có thể đ-ợc khởi x-ớng nhờ một
câu lệnh script chứa trong một trang ASP. Khi một trang ASP chứa
@TRANSACTION thì trang đó sẽ đ-ợc chạy trong giao tác đó và chỉ kết thúc khi
giao tác đó đã thành công hoặc thất bại. Và đối t-ợng ASPError chứa thông tin về
lỗi xuất hiện trong mã lệnh trong trang ASP.
b. File Global.asa
Là nơi khai báo các đối t-ợng, biến có phạm vi phiên làm việc hay toàn bộ
ứng dụng. File Global đ-ợc kích hoạt mỗi khi một phiên làm việc mới đ-ợc thiết
lập, tuy nhiên sự kiện Application_OnStart chỉ đ-ợc kích hoạt một lần khi
Webserver đ-ợc khởi động. Mỗi một ứng dụng chỉ có thể có duy nhất một file
Global.asa.
Các sự kiện của các đối t-ợng Application và Session đ-ợc khai báo trong
file Global.asa.
Cú pháp:
<Script Language=VBScipt RUNAT=Server>
Application_OnStart
End Sub
Application_OnEnd
End Sub
Session_OnStart
End Sub
Session_OnEnd
End Sub
</Script>
Ngoài ra ta có thể viết các hàm và thủ tục đặt trong file Global.asa để phục
vụ cho cả ứng dụng hay cho từng phiên làm việccụ thể, các thủ tục và các hàm này
phải nằm trong các sự kiện của hai đối t-ợng Application và Session.
4.6.2 Đối t-ợng Request
a. ýnghĩa:
Lấy yêu cầu từ máy khách nhờ ph-ơng thức HTTP . Là kiểu đối t-ợng quan
trọng nhất trong ASP. Thông qua việc sử dụng đối t-ợng Request ta có thể lấy
đ-ợc cả dữ liệu và tham số trong một trang HTML đ-ợc gửi qua đ-ờng địa chỉ.
Khi một Browser liên lạc với Server thông qua giao thức HTTP, Browser gửi
yêu cầu tới Server, ngoài tên của trang đ-ợc yêu cầu thì còn rất nhiều thông tin
http://www.ebook.edu.vn 90
khác đi kèm đ-ợc gửi tới Server. Các thông tin này có thể là các biến môi tr-ờng,
các thông tin do user cung cấp d-ới dạng điền vào các bảng,Cookies, ... Tất cả các
thông tin này đ-ợc mã hoá và truyền đi cùng với HTTP headers. ASP cho phép lấy
ra các thông tin này bằng cách sử dụng đối t-ợng Request.
b. Các thành phần của Request:
Tập hợp Thuộc tính Ph-ơng thức
QueryString
Form
ServerVariables
Cookies
ClientCertificate
TotalBytes BinaryRead
Cú pháp:
Request.[Tập hợp](Biến)|thuộc tính|ph-ơng thức
Tập hợp:
Tập hợp ýnghĩa
ClientCertificate Bao gồm các thông tin về certificate của Client.
Cookies Đọc thông tin từ một Cookies đã có sẵn
Form Giá trị các thành phần của form gửi đến từ Browser (Lấy
thông tin do user gửi đến bằng ph-ơng thức POST)
QueryString Lấy giá trị của các biến theo sau một URL (Lấy thông tin
do user gửi đến bằng ph-ơng thức GET)
ServerVariables Bao gồm các thông tin vềClient Browser, Server và user
c. Tập hợp Form và QueryString:
Khi chúng ta sử dụng thẻ <FORM> trong một trang, ta có thể đặt thuộc tính
METHOD của <FORM> là POST hay GET.Nếu chúng ta sử dụng GET (hay bỏ
qua vì GET là giá trị mặc định của METHOD), trình duyệt sẽ lấy các giá trị trong
tất cả các control để xây dựng thành QueryString và gắn vào URL của trnag đ-ợc
yêu cầu khi Submit trang hiện tại. Khi trang này đến Server các giá trị của nó nằm
ở Collection Request.QueryString.
Ng-ợc lại, nếu sử dụng ph-ơng thức POST, trình duyệt sẽ đ-a tất cả các giá
trị vào trong HTTP header gửi đến Server và các giá trị này có thể truy xuất qua
Collection Request.Form
Nói chung, ta nên sử dụng ph-ơng thức Post trong tất cả các form HTML.
Thứ nhất, chiều dài chuỗi của URL bị giới hạn nên nếu dùng QueryString sẽ có
nguy cơ bị tràn và bị cắt bớt. Thứ hai, query string đ-a các giá trị t-ờng minh vào
URL, và sẽ đ-ợc ghi lại trong file log khi điqua các Server, không bảo mật thông
tin.
Sự khác nhau giữa hai ph-ơng thức gửi dữ liệu từClient đến Server đ-ợc chỉ
ra trong sơ đồ sau:
http://www.ebook.edu.vn 91
Hình 4.7 Sự khác nhau giữa hai ph-ơng thức GET và POST.
Ví dụ sử dụng ph-ơng thức Post để gửi dữ liệu:
Nội dung file1.htm
<HTML>
<HEAD>
</HEAD>
<BODY>
<form action=“file2.asp">
Name:<input>
<br>Company:<input>
<br>Position:<input>
<br>Address:<textarea></textarea>
<br>Phone:<input>
<br><input>
</form>
</BODY>
</HTML>
Nội dung file2.asp
<HTML>
<HEAD>
</HEAD>
<BODY>
Server (ASP Application)
Client (Browser)
Form
METHOD=GET
(Giá trị Default)
Dữ liệu gửi với URL
Sử dụng QueryString
Collection đọc DL
Sử dụng Form
Collection đọc DL
Dữ liệu gửi trong
HTTP header
METHOD=POST
http://www.ebook.edu.vn 92
<% Response.Write Request.Form("Name")%>
works for<% Response.Write Request.Form("Company") %>
at address<% Response.WriteRequest.Form("Address") %>
as a<% Response.Write Request.Form("Position") %>.
</BODY>
</HTML>
Kết quả:
Jane Doe works for ISSI at address 5609 Kington Pike Knoville, TN as a
Web Designer.
Ví dụ sử dụng ph-ơng thức Get để gửi dữ liệu:
Nội dung file1.asp:
<HTML>
<HEAD>
</HEAD>
<BODY>
<A>
Query sample</A>
</BODY>
</HTML>
Nội dung file2.asp:
<%
For Each item In Request.QueryString
Response.Write item & " = " & Request.QueryString(item) & "<BR>"
Next
%>
Output:
language = ASP
type = general
Hoặc file2.asp có thể viết:
<%
Response.Write "language =" & Request.QueryString("language")&
"<BR>"
Response.Write "type =" & Request.QueryString("type")& "<BR>"
%>
Chú ý: Khi lấy giá trị theo 2 tập hợp là Form hoặc QueryString ta chỉ cần chỉ
ra Request(“tên_biến”)
Chẳng hạn: Request.Form(“Name”) cóthể thay bằng Request(“Name”)
d. Sử dụng tập hợp Cookies:
Cookies là nhóm văn bản màWebsite đặt vào một filetrên đĩa cứng của web
browser khi web browser truy cập Websiteđó. Cookie dùng để nhận diện khi Web
browser này truy cập những lần sau.
http://www.ebook.edu.vn 93
Cookie đ-ợc gửi đến Server cùng với mỗi yêu cầu. Dữ liệu trong Cookie
đ-ợc đặt trong tập hợp Cookies. Nó đ-ợc truy cập t-ơng tự QueryString và Form.
Tuy nhiên, sử dụng đối t-ợng Request, ta chỉ đọc đ-ợc giá trị của Cookie mà không
thay đổi đ-ợc nó.
Ví dụ:
<%
Response.Cookies("myProduct")("Main") = "DevSite"
Response.Cookies("myProduct")("Prd1") = "ASP"
Response.Cookies("myProduct")("Prd2") = "VBScript"
Response.Write Request.Cookies("myProduct")
%>
Kết quả:
PRD2=VBScript&PRD1=ASP&MAIN=DevSite
e. Sử dụng tập hợp ServerVariables:
Giá trị của các biến môi tr-ờng server. Điều này sẽ chép truy nhập tới các
header HTTP.
Ví dụ:
<%IPAddress = Request.ServerVariables("REMOTE_ADDR")
Software = Request.ServerVariables("SERVER_SOFTWARE")
Protocol = Request.ServerVariables("SERVER_PROTOCOL")
Response.Write "Your IP Address is " & IPAddress & " and your server
is running " & Software & " under " & Protocol & "protocol."
%>
Kết quả
Your IP Address is 127.0.0.1 and your server is running Microsoft-IIS/4.0
under HTTP/1.1 protocol.
Hoặc ta có thể tham chiếu tới tất cả các tham số của tập hợp ServerVariables
nh-sau:
<% For each item in request.servervariables
Response.write “<br>” & item & “=” & request.servervariables(item)&
“<br>”
Next
%>
f. Thuộc tính:
TotalBytes: Chỉ ra tổng số byte máy khách gửi tới máy chủ trong phần
thân yêu cầu HTTP.
g. Ph-ơng thức:
BinaryRead:Đọc dữ liệu từ thân HTTP gửi đến server .
Ví dụ:
-------------------File1.html-----------------
<HTML>
<HEAD>
http://www.ebook.edu.vn 94
</HEAD>
<BODY>
<FORM>
Name:<INPUT>
<BR>
Age: <INPUT><BR>
Sex: <INPUT><BR>
<INPUT><BR>
</FORM>
</BODY>
</HTML>
-------------------File2.asp------------------
<%
Dim ByteCount,BinRead
ByteCount = Request.TotalBytes
BinRead=Resquest.BinaryRead(ByteCount)
Response.Write("ByteCount = " & ByteCount & " bytes")
%>
Kết quả:
Tùy thuộc vào dữ kiện đ-ợc nhập tại form, ví dụ nếu Name=Bill, Age=56,
and Sex=male. Thì ta sẽ có kết quả là:
ByteCount = 39 bytes
4.6.3 Đối t-ợng Response
Đ-ợc sử dụng để truy xuất các đáp ứng mà server tạo ra để gửi về cho user
Tập hợp Thuộc tính Ph-ơng thức
Cookies Buffer
Charset
ContentType
Expires
ExpiresAbsolute
Status
AddHeader
AppendToLog
BinaryWrite
Clear
End
Flush
Redirect
Write
Cú pháp:
Response.tập hợp|thuộc tính|ph-ơng thức
a. Tập hợp:
Cookies:Xác định giá trị của cookie gửi cho browser . Các thành phần của
tập hợp này đều là giá trị chỉ ghi.
Request object cho phép chúng ta đọc thông tin của cookies khi có 1 yêu cầu
đ-ợc gửi đến. Còn Responseobject cung cấp khả năng đặt hoặc thay đổi các giá trị
của cookies tr-ớc khi gửi trả lại cho client.
http://www.ebook.edu.vn 95
Ví dụ:
Dòng lệnh sau đây sẽ thêm 1 cookievào cookie của client nếu nó ch-a đ-ợc
đặt hoặc thay đổi giá trị của cookie này nếu nó đã tồn tại.
<% Response.cookies(“independentcookie”)=”4
th
of July”%>
Chú ý:Việc thay đổi cookie với Response object cần đ-ợc làm tr-ớc khi viết
mã văn bản hoặc HTML để gửi tới client, nếu không sẽgây ra lỗi.
b. Ph-ơng thức :
Ph-ơng thức ýnghĩa
AddHeader Thêm phần đầu HTTP với một giá trị cụ thể để gửi lại cho
browser
AppendToLog Thêm một chuỗi văn bản vào mục nhập nhật ký máy chủ cho
yêu cầu từ máy khách hiện thời
Binarywrite Viết thông tin trực tiếptới nội dung tín hiệu đáp mà không
chuyển đổi ký tự nào
Clear Xoá bộ đệm
End Dừng việc xử lý 1 trang vàtrả lại kết quả hiện tại
Flush Gửi những dữ liệu có trong bộ đệm tới browser ngay lập tức
Redirect Chỉ cho browser kết nối đến một URL khác
Write Gửi text trực tiếp tới trình duyệt phía user
? AddHeader: Response.AddHeader Name, Value
Đặt tên header HTML: Phải đ-ợc gọi tr-ớc khi output đ-ợc gửi cho client trừ
khi response.buffer đ-ợc đặt là true.
Ví dụ:
<%
Response.AddHeader "MyHeader", "ERROR"
%>
? AppendToLog : Response.AppendToLog(String)
Thêm xâu vào cuối mục log Web server cho yêu cầu này. String lớn nhất là
80 ký tự
Ví dụ:
<%
Response.AppendToLog("Error in Processing")
%>
Đầu ra đ-ợc chèn vào cuối file IIS log:
10.78.176.37, - , 03/20/97, 7:55:20, W3SVC, SALES1, 10.78.176.37, Error
in Processing
? Clear: Response.Clear
Xóa toàn bộ output HTML đang ở trong buffer, không xóa header, chỉ xóa
phần thân (body). Nếu buffer không đ-ợc thiết đặt sẽ gây ra lỗi. Phải đặt
Response.Buffer=True (mặc định trong phiên bản 3.0)
Ví dụ:
<%Response.Clear %>
? End: Response.End
Kết thúc xử lý file .asp và trả lại kết quả hiện tại
Ví dụ:
<%
Response.Write "Hello World"
Response.End
Response.Write "Is this the End?"
%>
Kết quả:
Hello World
? Flush:Response.Flush
Gửi thông tin trong buffer ra ngay lập tức
Response.buffer=true
Ví dụ:
<%Response.Flush %>
? Redirect: Response.Redirect(URL)
Kết thúc xử lý file .asp hiện tại, chuyển trình duyệt tới một URL khác.
Ví dụ:
--------------File1.asp---------------
<%
Response.Write "This is File1.asp and switching to File2.asp"
Response.Redirect "File2.asp"
Response.Write "This line is not written to the file"
%>
--------------File2.asp-----------------
<%
Response.Write "This is File2.asp"
%>
Kết quả:
File1 đ-ợc thực hiện sau đó trình duyệt sẽ tải File2 lên:
------------File1.asp------------------
This is File1.asp and switching to File2.asp
------------File2.asp-------------------
This is File2.asp
? Write: Response.Write(Variant)
Ghi thông tin d-ới dạng xâu vào output HTTP hiện thời.
Ví dụ:
<%
Response.Write "Hello World"
Response.Write "<BR>"%>
Kết quả:
Hello World
c. Thuộc tính:
Thuộc tính ýnghĩa
Buffer Xác định xem một trang cósử dụng bộ đệm để chứa các
kết quả đ-ợc tạo bởi Script hay đ-ợc gửi ngay tới
browser khi từng dòng đ-ợc tạo ra và nhập vào dải
HTML. Giá trị ngầm định là False
ContentType Xác định kiểu nội dung HTTP đ-ợc trả về. Kiểu ngầm
định là Text/HTML
Expires Khoảng thời gian 1 trang Web đ-ợc l-u giữ trên browser
ExpiresAbsolute Ngày và thời gian 1 trang Web đ-ợc l-u giữ trên browser
Status Giá trị của dòng trạng thái HTTP trả lại bởi server
Charset Đặt dạng ngôn ngữ sử dụng cho client browser vào phần
cuối của đoạn đầu ContentType
? Buffer
• Buffer: nơi l-u giữ tạm thời tr-ớc khi chuyển cho trình duyệt
• Chỉ ra output của trang có đ-ợc l-u trong buffer hay không
• Sẽ không có sự gửi lại cho trình duyệt cho đến khi tất cả các script
đ-ợc xử lý xong, hoặc có lời gọi ph-ơng thức Flush hay End.
Thuộc tính này không thể thay đổi khi server đã gửi thông tin cho trình duyệt
và phải đ-ợc đặt ở dòng đầu tiên trong file .asp
Ví dụ:
<%
Response.Buffer = TRUE
x=0
Do
x = x+1
Response.Write x & "<BR>"
Loop
%>
? Response.CacheControl
Có cho phép máy chủ proxy đ-ợc cache output của trang .asp hay không.
Máy chủ proxy dùng để đẩy nhanh tốc độ truy nhập tới trang Web nào đó
bằng cách l-u lại một bản của trang Web trong cache.
• Nếu CacheControlđ-ợc đặt là “Public”, thì cho phép cache.
• Nếu CacheControlđặt là “Private”, thì không cho phép cache.
Ví dụ:
<% Response.CacheControl = "Public" %>
<% Response.CacheControl = "Private" %>
http://www.ebook.edu.vn 98
? Charset: Response.Charset
Thêm tên của tập ký tự vào trong header content-type
Mặc định là ISO-LATIN-1
Ví dụ:
Trong ví dụ này, nếu header là: content-type: text/html
Thì header sẽ trở thành:
content-type: text/html; charset = MS_Kanji
<% Response.Charset("MS_Kanji") %>
? ContentType: Response.ContentType
Chỉ ra kiểu nội dung HTTP để trả lại. Mặc định là text/HTML
Ví dụ:
<% Response.ContentType = "application/vnd.ms-excel" %>
? Expires
Xác định khoảng thời gian tr-ớc khi một trang đ-ợc cache hết hạn
Ví dụ:
• Tr-ờng hợp 1: bất kỳ khi nào gọi tới trang đó, nó luôn luôn đ-ợc
refresh.
• Tr-ờng hợp 2: Nếu trở lại trang đó tr-ớc 15 phút, trang hiển thị sẽ là
trang ở trong cache.
<% Response.Expires = 0 %>
<% Response.Expires = 15 %>
? Response.ExpiresAbsolute
Xác định ngày và thời gian chính xác một trang sẽ hết hạn.
Ví dụ:
<% Response.ExpiresAbsolute=#May 15, 1999 18:00:00# %>
? Response.IsClientConnected
• Xác định xem client đã ngừngkết nối với server từ Response.Write
cuối cùng.
• Thuộc tính này đặc biệt có ý nghĩa để server không phải tiếp tục thực
hiện chuyển những thông tin client không yêu cầu.
Ví dụ:
<%
'Check to see if the client is connected.
If Not Response.IsClientConnected Then
'Get the sessionid to send to the shutdown function.
Shutdownid = Session.SessionID
'Perform shutdown processing.
Shutdown(Shutdownid)
End If
%>
http://www.ebook.edu.vn 99
? Response.Status
Dòng trạng thái do server trả lại
Ví dụ:
<%
IPAddress = Request.ServerVariables("REMOTE_ADDR")
If IPAddress <> "208.5.64.223" Then
Response.Status = "403 Access Forbidden"
Response.Write Response.Status
Response.End
End If
%>
<BODY>
You have accessed this page through the IP Address of
208.5.64.223.
</BODY>
Kết quả sau sẽ đ-ợc trả về nếu địa chỉ IP trên máy Client là 208.5.64.223:
You have accessed this page through the IP Address of 208.5.64.223.
Ng-ợc lại nếu địa chỉ IP của Clientkhông phải là 208.5.64.223 thì kết quả
sau sẽ trả về:
403 Access Forbidden
4.6.4 Đối t-ợng Server
Cho phép truy nhập tới các ph-ơng thức và thuộc tính trên máy chủ.
Tập hợp Thuộc tính Ph-ơng thức
ScripTimeOut
CreateObject
HTMLEncode
MapPath
URLEncode
Cú pháp:
Server.Thuộc tính|Ph-ơng thức
a. Thuộc tính:
ScriptTimeout: Server.ScriptTimeout
thời gian tối đa để trang script chạytrên máy chủ. Nếu không đặt giá trị cho
thuộc tính này thì giá trị mặc định của nó là 90 giây.
Nếu script nhập vào một vòng lặp vô hạn thì server sẽ kết thúc script đó để
tránh bị overload bởi việc chạy liên tục các tiến trình sinh ra. Thời gian tr-ớc khi
script bị kết thúc đ-ợc định nghĩa bởi thuộc tính này.
<% Server.ScriptTimeout = 150 %>
Ta có thể lấy đ-ợc giá trị của thuộc tính ScriptTimeout bằng cách:
<% timeout = Server.ScriptTimeout %>
b. Ph-ơng thức
Ph-ơng thức ýnghĩa
CreateObject Tạo một thể hiện của đối t-ợng cụ thể trên Server
Execute Cho phép g?i trang ASP khác trong m?t trang ASP
GetLastError Mô tả đối t-ợng lỗi ASP, chỉ có ý nghĩa tr-ớc khi file asp
gửi nội dung tới Client
HTMLEncode Gắn một đoạn mãHTML vào một xâu đã đ-ợc định dạng.
MapPath Xác định đ-ờng dẫn vật lý trên máy chủ khi xét đết đ-ờng
dẫn ảo.
Transfer Chuy?n tới trang ASP khác từ một trang ASP. Thông tin
trạng thái hiện tại trong trang đầu tiên sẽ đ-ợc chuyển tới
trang thứ hai
URLEncode Cho phép gắn một đoạn mã URL
? Server.CreateObject(ObjectID)
Tạo một thể hiện (instance) của đối t-ợng server (đối t-ợng activeX bất kỳ
trên server), sau đó có thể sử dụng các ph-ơng thức và truy cập tới các thuộc tính
của đối t-ợng đó.
ObjectID là đối t-ợng cần khởi tạo.
Đoạn mã sau dùng để kết nối với CSDL:
<% Set myconn = Server.CreateObject("ADODB.Connection") %>
? Server.Execute (Path)
• Cho phép gọi trang ASP khác trong một trang ASP. Khi trang đ-ợc gọi
tới hoàn thành các công việc của nó, sẽtrở lại tiếp tục thực hiện trang
ASP gọi tới nó. Hiệu quả giống nh-các hàm, thủ tục (subroutines).
Ph-ơng pháp có hiệu quả t-ơng tự include.
• Ph-ơng thức Transfer chuyển tới trang ASP khác không quay lại trang
đã gọi tới.
• Tham số Path chỉ đ-ờng dẫn t-ơng đối hoặc vật lý, toàn bộ xâu này
đ-ợc đặt trong dấu nháy.
Ví dụ:
----------CallingAsp.asp----------
<HTML>
<BODY>
How now <%Server.Execute("CalledAsp.asp")%> cow?
</BODY>
</HTML>
----------CalledAsp.asp----------
<%
Response.Write "pink"
%>
http://www.ebook.edu.vn 101
Kết quả:
How now pink cow?
? Server.GetLastError
Trả lại đối t-ợng ASPError, đối t-ợng này có 9 thuộc tính chỉ đọc cung cấp
thông tin chi tiết về lỗi.
Ví dụ:
<%
Dim objErrorInfo
Set objErrorInfo = Server.GetLastError
Response.Write("ASPCode = " & objErrorInfo.ASPCode)
Response.Write("ASPDescription = " & objErrorInfo.ASPDescription)
Response.Write("Category = " & objErrorInfo.Category)
Response.Write("Column = " & objErrorInfo.Column)
Response.Write("Description = " & objErrorInfo.Description)
Response.Write("File = " & objErrorInfo.File)
Response.Write("Line = " & objErrorInfo.Line)
Response.Write("Number = " & objErrorInfo.Number)
Response.Write("Source = " & objErrorInfo.Source)
%>
? Server.HTMLEncode (String)
Ph-ơng thức này cho phép mã hoá chuỗithành mã HTML đối với xâu ASCII
bất k?. Ví dụ, điều này cho phép hiển thị thẻ HTML mà không xử lý nó nh-những
thẻ HTML thực sự.
Ví dụ:
<% Response.Write Server.HTMLEncode("The tag for a table is: <Table>") %>
Kết quả:
The tag for a table is: <Table>
Kết quả ở Browser:
The tag for a table is: <Table>
? Server.MapPath (Path)
ánh xạ đ-ờng dẫn ảo, hay t-ơng đối tới đ-ờng dẫn vật lý. Ph-ơng thức này
không kiểm tra sự tồn tại thực sự của đ-ờng dẫn. Nếu bắt đầu bằng dấu / hoặc \ ->
đ-ờng dẫn ảo. Còn không bắt đầu bằng ký tự đó -> đ-ờng dẫn t-ơng đối.
Ví dụ:
<HTML>
<BODY>
The path of this file is <% Response.Write
Server.MapPath("test.asp")%>
The path of the file1 is <% Response.Write
Server.MapPath("\test.asp")%>
The path of the file2 is <% Response.Write
Server.MapPath("test\test.asp") %>
http://www.ebook.edu.vn 102
The path of the file3 is <% Response.Write Server.MapPath("\") %>
</BODY>
</HTML>
Kết quả:
The path of this file is C:\VANBANG2\ASP\Example\test.asp
The path of the file1 is d:\inetpub\wwwroot\test.asp
The path of the file2 is C:\VANBANG2\ASP\Example\test\test.asp
The path of the file3 is d:\inetpub\wwwroot
? Server.Transfer (Path)
Chuyển tới trang ASP khác từ một trang ASP. Thông tin trạng thái khởi tạo
trong trang đầu tiên sẽ đ-ợc chuyển tới trang thứ hai.
Ví dụ:
----------CallingAsp.asp----------
<%
Application("name") = "Application Maker"
Application("publishdate") = "05/15/01"
Application("author") = "DevGuru"
Set Application("Obj1") =
Server.CreateObject("ADODB.Connection")
Server.Transfer("CalledAsp.asp")
%>
----------CalledAsp.asp----------
<%;
Response.Write "Outputfrom CalledAsp.asp"
For Each Item in Application.Contents
If IsObject( Application.Contents(Item)) Then
Response.Write Item & “is an object.<BR>”
Else
Response.Write Item & “=” & Application.Contents(Item) &“<BR>”
End If
Next
%>
Kết quả:
Kết quả từ CalledAsp.asp
name=Application Maker
publishdate=05/15/01
author=DevGuru
OBJ1 is an object.
? Server.URLEncode(String)
Chuyển xâu thành dạng mã hoá URL, đểđảm bảo hyperlink trong ASP đó đ-ợc
định dạng đúng đắn.
http://www.ebook.edu.vn 103
Ví dụ:
<% Response.Write Server.URLEncode("http://www.issi.net") %>
Kết quả:
http%3A%2F%2Fwww%2Eissi%2Fnet
4.6.5 Đối t-ợng Application
Một ứng dụng bao gồm các file có thể truy nhập thông qua một th-mục ảo
xác định và các th-mục con của nó.
Đối t-ợng Application thể hiện toàn bộ một ứng dụng ASP. Chúng ta có thể
sử dụng ứng dụng này để chia sẻ thông tin cho tất cả các ng-ời dùng trong một ứng
dụng.
Đối t-ợng Application đ-ợc bắt đầu khi có một yêu cầu đầu tiên một trang
web bất kỳ từ th-mục ảo tại Web server và tồn tại cho đến khi Webserver ngừng
hoạt động.
a. Tập hợp:
? Application.Contents(Key)
Chứa danh sách các mục vừa đ-ợc khởi tạo và đ-a vào đối t-ợng
Application.
Ví dụ:
<% Application("name") = "Application Maker"
Application("publishdate") = "05/15/01"
Application("author") = "DevGuru"
Set Application("Obj1") = Server.CreateObject("ADODB.Connection")
For Each Item in Application.Contents
If IsObject( Application.Contents(Item)) Then
Response.Write Item & " is an object.<BR>"
Else
Response.WriteItem & "=" & Application.Contents(Item) & "<BR>"
End If
Next
%>
Kết quả:
name=Application Maker
publishdate=05/15/01
author=DevGuru
OBJ1 is an object
? Ph-ơng thức của tập hợp Contents:
• Application.Contents.Remove (Name|Integer)
Loại bỏ mục nào đó trong collection Application.Contents
Namechỉ ra tên mục sẽ xóa, nằm trong cặp dấu nháy (“”). Integerchỉ ra vị
trí mục trong collection sẽ đ-ợc xóa. Giá trị này bắt đầu từ 1.
Ví dụ:
<%
Application("name") = "Application Maker"
Application("publishdate") = "05/15/01"
Application("author") = "DevGuru"
Set Application("Obj1") = Server.CreateObject("ADODB.Connection")
Application.Contents.Remove(1)
Application.Contents.Remove("publishdate")
For Each Item in Application.Contents
If IsObject(Application.Contents(Item)) Then
Response.Write Item & " is an object.<BR>"
Else
Response.WriteItem & "=" &Application.Contents(Item) & "<BR>"
End If
Next
%>
Kết quả:
author=DevGuru
Obj1 is an object.
• Application.Contents.RemoveAll
Loại bỏ tất cả các mục trong collection Application.Contents.
Thêm cặp dấu ngoặc ()
<%Application.Contents.RemoveAll( )%>
? Application.StaticObjects(Key)
Chứa tất cả các mục đó đ-ợc tạo trong ứng dụng bằng thẻ <OBJECT.
----------Global.asa-------------
<OBJECT RUNAT=Server SCOPE=Application
ID=MyInfo>
</OBJECT>
<OBJECT RUNAT=Server SCOPE=Application
ID=MyConnection>
</OBJECT>
<OBJECT RUNAT=Server SCOPE=Application
ID=MyADRot>
</OBJECT>
-----------File.asp----------------
<%
For Each Item In Application.StaticObjects
Response.Write Item & "<BR>"
Next
%>
http://www.ebook.edu.vn 105
Kết quả:
MyInfo
MyConnection
MyADRot
b. Sự kiện:
ứng với hai hoạt động bắt đầu và kết thúc một đối t-ợng Application ta có hai
sự kiện trong đối t-ợng Application, đó là:
Application_OnStart(khởi tạo các thông tin phục vụ cho một ứng dụng khi
ứng dụng bắt đầu) và Application_OnEnd(đ-ợc kích hoạt khi ứng dụng kết thúc)
Cú pháp của sự kiện Application_OnStart:
<SCRIPT LANGUAGE=VBScript RUNAT=Server>
Sub Application_OnStart
' Nơi chèn đoạn Script cần thiết cho việc khởi tạo một ứng dụng
End Sub
Sub Application_OnEnd
' Nơi chèn đoạn Scipt cần thiết cho việc kết thúc một ứng dụng
End Sub
</SCRIPT>
Chú ý:Phải khai báo ngôn ngữ script đ-ợc sử dụng trong các đoạn script sự
kiện trong dòng đầu tiên của file global.asa
- Các đối t-ợng của ASP trong phần này chỉ có SERVER và APPLICATION
-------------------Global.asa--------------------------
<script RUNAT=Server>
Sub Application_OnEnd()
End Sub
Sub Application_OnStart()
Application("NumSession") = 0
Application("NumVisited") = 0
Session.Timeout = 10
End Sub
Sub Session_OnEnd()
Application("NumSession") = Application("NumSession") – 1
End Sub
Sub Session_OnStart()
Application("NumSession") = Application("NumSession") + 1
Application("NumVisited") = Application("NumVisited") + 1
End Sub
</script>
-------------------File1.asp----------------------------
Response.Write "You are " & Application("NumSession") & " of "
& Application("NumVisited") & " users."
http://www.ebook.edu.vn 106
Kết quả:
You are 1 of 1 users.
c. Ph-ơng thức:
Vì đối t-ợng Application có thể đ-ợc chia sẻ thông tin giữa các ng-ời dùng
do đó để đảm bảo những ng-ời dùng đó không thể cùng một lúc thay đổi nội dung
của một biến trong đối t-ợng Application nó có hai ph-ơng thức là Lock và
Unlock.
Ph-ơng thức ýnghĩa
Lock Ph-ơng thức Lock ngăn cản các client khác cùng một lúc thay
đổi giá trị của một biến do đối t-ợng Application l-u trữ
Unlock Ph-ơng thức Unlock cho phép các client có thể sửa đổi các
thuộc tính của đối t-ợng Application .
4.6.6 Đối t-ợng Session
Đối t-ợng Sesion đ-ợc dùng để l-u trữ thông tin cần thiết cho một phiên làm
việc của ng-ời dùng cụ thể. Các biến l-u trữ trong đối t-ợng Session không bị mất
khi ng-ời dùng truy cập các trang Web khác trong ứng dụng. Thay vào đó các biến
này tồn tại trong toàn bộ phiên làm việc của ng-ời dùng.
Khi một ng-ời dùng mới yêu cầu một trang Web từ ứng dụng, Web server tự
động tạo một đối t-ợng Session và server sẽ phá huỷ đối t-ợng Session khi phiên
làm việc kết thúc hoặc bị huỷ bỏ. Có thể đặt thời gian tồn tại cho một phiên làm
việc tuy nhiên giá trị ngầm định cho một phiên làm việc tồn tại là 20 phút.
a. Tập hợp:
? Session.Contents(Key)
Chứa danh sách các mục đã khởitạo và thêm vào bằng đối t-ợng session.
Không phải khởi tạo bằng thẻ <object>
Ví dụ:
<%
Session("name") = "Application Maker"
Session("publishdate") = "05/01/99"
Session("author") = "ISSI"
Set Session("Obj1") = Server.CreateObject("ADODB.Connection")
For Each Item in Session.Contents
If IsObject( Session.Contents(Item)) Then
Response.Write Item & " is an object.<BR>"
Else
Response.Write Item & "=" & Session.Contents(Item) & "<BR>"
End If
Next
%>
Kết quả:
NAME=Application Maker
http://www.ebook.edu.vn 107
PUBLISHDATE=05/01/99
AUTHOR=ISSI
OBJ1 is an object.
? Session.StaticObjects(Key)
Chứa danh sách các mục vừa đ-ợc khởi tạo và đ-a vào đối t-ợng Session nhờ
sử dụng thẻ HTML <OBJECT>.
Ví dụ:
----------Global.asa-------------
<OBJECT RUNAT=Server SCOPE=Session ID=MyInfo
PROGID="MSWC.MyInfo">
</OBJECT>
<OBJECT RUNAT=Server SCOPE=Session
ID=MyConnection>
</OBJECT>
<OBJECT RUNAT=Server SCOPE=Session ID=MyADRot
PROGID="MSWC.ADRotator">
</OBJECT>
-----------File.asp-----------------
<%
For Each Item In Session.StaticObjects
Response.Write Item & "<BR>"
Next
%>
Kết quả:
MyInfo
MyConnection
MyADRot
b. Sự kiện:
Cũng nh-đối t-ợng Application, đối t-ợng Session có hai sự kiện là
Session_OnStart( đ-ợc kích hoạt khi mỗi khi một phiên làm việc bắt đầu) và
Session_OnEnd (đ-ợc kích hoạt khi kết thúc một phiên làm việc)
Cú pháp
<SCRIPT LANGUAGE=VBScript RUNAT=Server>
Sub Session_OnStart
' Nơi chèn đoạn Script cần thiết cho việc khởi tạo một phiên
làm việc
End Sub
Sub Session_OnEnd
' Nơi chèn đoạn Script cần thiết khi một phiên làm việc kết thúc
End Sub
</SCRIPT>
http://www.ebook.edu.vn 108
c. Thuộc tính:
Thuộc tính ýnghĩa
SessionID Trả về giá trị nhận biết duynhất từng phiên làm việc của một
ng-ời sử dụng
Timeout Khoảng thời gian ngầm định là 20’ cho sự tồn tại của một phiên
làm việc trong một ứng dụng. Máy chủ Web sẽ duy trì thông
tin phiên làm việc của ng-ời sử dụng mà không đ-a ra yêu cầu
hay làm mới lại một trang.
d. Ph-ơng thức:
? Abandon: Huỷ bỏ một đối t-ợng Session và giải phóng các biến trong
đối t-ợng Session.
? Session.Contents.Remove (Name|Integer)
Dùng để xóa tất cả các mục trong collection Session.Contents
Có 2 lựa chọn tham số Namehoặc Integer
• Name chỉ tên của mục cần xóa
• Integer là số chỉ vị trí (bắt đầu từ 0) của mục cần xóa.
? Session.Contents.RemoveAll
Xóa tất cả các mục trong session.contents
Ví dụ:
<%Session.Contents.RemoveAll( )%>
Chú ý: Có thể l-u trữ các giá trị trong đối t-ợng Session. Thông tin l-u trữ
trong đối t-ợng Session có phạm vi phiên làm việc và có thể sử dụng đ-ợc trong
suốt một phiên làm việc.
4.7 Câu hỏi và bài tập ch-ơng 4
4.7.1 Câu hỏi ôn tập
1. ASP là viết tắt của cụm từ nào?
a. All Standard Pages
b. Active Server Pages
c. Active Standard Pages
d. A Server Page
2. Nội dung của đoạn script ASP đ-ợc định nghĩa bởi cặp thẻ nào d-ới đây?
a. <&>...</&>
b. <%>...</%>
c. <script>...</script>
d. <%...%>
3. IIS là gì? Nó hoạt động nh-thế nào?
4. Các b-ớc thiết lập th-mục ảo trong IIS.
5. Các lệnh cơ bản của ASP.
4.7.2 Bài tập về các cấu trúc điều khiển và vòng lặp.
1. Viết đoạn mã ch-ơng trình ASP dùng cấu trúc Select...Case để hiển thị ra
màn hình ngày hiện hành trong tuần bằng tiếng Việt.
2. Viết đoạn mã ch-ơng trình ASP dùng vòng lặp Do...Loop để viết ra màn
hình 10 dòng chữ “Hello world” có kích th-ớc tăng dần.
4.7.3 Bài tập về các đối t-ợng.
1. Viết ra màn hình câu “Hello world”
2. Viết một form lấy ý kiến của ng-ời sử dụng về trang web của mình, rồi
hiển thị các thông tin ng-ời sử dụng điền vào ra màn hình.
3. Thiết kế và cài đặt trang Web hiển thị máy tính tay với các phép toán
cộng, trừ, nhân, chia, lũy thừa, căn bậc hai, bình ph-ơng, nghịch đảo.
4. Viết một đoạn code dùng để đếm số lần truy cập vào một trang Web. Sau
đó nhúng vào trang Web đã làm ở bài 2.
5. Thiết kế và cài đặt trang Web hiển thị lịch (calendar). Trang Web phải cho
phép ng-ời dùng xem lịch tháng của một năm nào đó, xem lịch của các tháng tr-ớc
và sau tháng hiện tại của năm hiện tại.
6. Thiết kế và cài đặt trang Web hiển thị hệ thống cây th-mục của máy chủ.
Ch-ơng 5
Kết nối cơ sở dữ liệu trong lập trình Web động với ASP
5.1 Khái niệm về ADO
ActiveX Data Object là lớp đối t-ợng COM (Compenent Object Model) tập
trung vào xử lý dữ liệu thông qua OLEDB của Windows. ADO thiết kế cho mục
đích truy xuất dữ liệu tổng quát không chỉ dùng để truy xuất dữ liệu thuần tuý mà
còn xử lý đ-ợc cả dữ liệu file hay bất kỳ loại dữ liệu nào có hỗ trợ cơ chế cho phép
giao tiếp thông qua OLEDB.
Mô hình kiến trúc của ADO t-ơng tác giữa ứng dụng và nguồn dữ liệu:
Hình 5.1 Mô hình kiến trúc của ADO.
5.2 Trình tiêu thụ (consumer) và trình cung cấp (provider)
Trong b-ớc lập trình, ch-ơng trình viết ra chính là trình tiêu thụ dữ liệu bởi
nó cần truy xuất vào các nguồn dữ liệu để xửlý. Còn trình cung cấp là tập lệnh cho
phép truy xuất vào nguồn dữ liệu theo cách đặc tr-ng của chúng. Provider cho phép
giao tiếp giữa nguồn dữ liệu và tầng điều khiển OLEDB. Và ADO chỉ trao đổi với
nguồn dữ liệu thông qua OLEDB mà không cầnquan tâm tới cách thức làm việc
của Provider. Để giúp OLEDB biết đ-ợc Provider nào cần phải giao tiếp, khi mở
kết nối ADO cần chỉ định trình cung cấp dữ liệu Provider t-ơng ứng. Microsoft
cung cấp sẵn một số Provider cho phép truy xuất dễ dàng vào các nguồn dữ liệu
đang thông dụng nh-:
• Jet OLEDB 4.0 – Cơ sở dữ liệu Access
• DTS Packages – Dịch vụ chuyển đổi dữ liệu trong SQL Server
• ODBC Driver – Provider ch phép truy xuất nguồn dữ liệu thông qua ODBC
• SQL Server – Cơ sở dữ liệu SQL Server
• Oracle – Cơ sở dữ liệu Oracle
• Simple Provider – Cơ sở dữ liệu dạng Text
VC++ VB Script Java
OLEDB
Data Store
E-mail CSDL File
ADO
Application
http://www.ebook.edu.vn 111
5.3 Mô hình đối t-ợng ADO
5.3.1 Đối t-ợng kết nối (Connection)
Cho phép thực hiện việc mở kết nối đến nguồn dữ liệu cần truy xuất. Thông
qua Connection chỉ cần chỉ định trình cung cấp OLEDB Provider sẽ dùng để tiếp
cận dữ liệu. Các thông tin kết nối bổ sung khác nh-username, password, server
name,.. th-ờng đ-ợc l-u vào một chuỗi gọi là chuỗi kết nối (Connection String).
Chú ý: Có thể kết nối và truy xuất vào nguồn dữ liệu màkhông bắt buộc phải
dùng đối t-ợng Connection. Cá đối t-ợng khác nh-Command, RecordSet,
Record,... cũng cho phép mở trực tiếp kết nối. Tuy nhiên sử dụng đối t-ợng
Connection sẽ cho phép bạn tách biệt thao tác kết nối và thao tác truy cập cơ sở dữ
liệu. Hơn nữa đối t-ợng Connection còn cung cấp thêmmột số chức năng chuyên
dụng khác nh-cho phép thực thi câu lệnh SQL tác động vào dữ liệu nh-Insert,
Update, Delete, gọi thủ tục Procedure Store,... hoặc kiểm soát giao tác transaction
nh-Rollback, commit.
5.3.2 Đối t-ợng Command:
Đối t-ợng này dùng cho mục đích thực thi câu lệnh tốt hơn Connection. Cho
phép bạn chuyển tham số vào các lệnh thực thi SQL. Tham số có thể chỉ định kiểu
hoặc giá trị t-ờng minh. Các tham số có thể nhận trị trả về sau khi thực
thi..Command có thể dùng cho cả 2 mục đích: thực thi câu lệnh SQL không cần
nhận kết quả trả về nh-Insert, Update, Delete, Procedure Store, hoặc thực thi các
lệnh trả về tập RecordSet nh-lệnh Select.
5.3.3 Đối t-ợng RecordSet:
Là đối t-ợng sử dụng th-ờng xuyên trong ADO. Cung cấp kết quả trả về từ
câu lệnh truy vấn một tập các bản ghi. Trang ASP có thể dùng vòng lặp để duyệt
qua các bản ghi này và hiển thị dữ liệu kết xuất ra trang Web phía trình duyệt.
Ngoài ra RecordSet còn cho phép thực hiệnlọc dữ liệu từ tập các bản ghi, truy xuất
đến tong tr-ờng cụ thể của bản ghi thông qua đối t-ợng Field hoặc danh sách các
tr-ờng trong bản ghi thông qua đối t-ợng Fields
5.4 Kết nối với nguồn dữ liệu
Chuỗi kết nối đ-ợc dùng để cung cấp thông tin cho đối t-ợng Connection
biết đặc điểm của cơ sở hay nguồn dữ liệu mà ADO cần truy xuất.
5.4.1 Tạo một ODBC DSN
Tr-ớc khi tạo các Script truy xuất cơ sở dữ liệu (CSDL), ta cần chỉ dẫn cho
ADO xác định nguồn dữ liệu cần truy xuất và cách thức liên kết CSDL.
Phổ biến và đơn giản nhất đó là sử dụng tên nguồn dữ liệu (Data Source
Name-DSN) để định vị và cấu hình nguồn dữ liệu t-ong thích chuẩn ODBC. Với
ODBC bạn có thể lựa chọn các kiểu DNS để tạo, đó là: User, System hoặc File. Các
DNS User và System th-ờng trú trong registry của hệ điều hành WindowsNT.
System DNS cho phép tất cả ng-ời sử dụng truy nhập vào Server đó đều có thể truy
xuất một CSDL, trong khi đó User DNS hạn chế đối với mỗi ng-ời sử dụng đăng
nhập vào Server; File DSN sẽ l-u thông tin d-ới dạng file cho phép nhiều ng-ời sử
dụng truy xuất CSDL và dễ dàng chuyển từ Server này sang Server khác chỉ bằng
việc copy các tệp DSN. Chúng ta có thể tạo ra DSN bằng cách:
• Vào trong Start\Control Panel, click chuột vào biểu t-ợng ODBC, chọn
một dạng DSN.
• Click Add, chọn một trình điềukhiển dữ liệu(.MDB, SQL)
• Theo các chỉ dẫn trên màn hình để cấu hình DSN cho CSDL
Sau đây là một số kết nối đến các loại CSDL thông dụng:
5.4.2 Cơ sở dữ liệu MS Access
connStr=“Provider=Microsoft.JetOLEDB.4.0; Data Source =
C:\Program Files\Microsoft Visual Studio\VB98\BIBLIO.MDB;
Persist Security Info=False”
set conn=Server.CreateObject(“ADODB.Connection”)
conn.open connStr
5.4.3 Cơ sở dữ liệu MS Access thôngqua trình điều khiển ODBC
connStr=“Driver=Microsoft Access Driver (*.mdb); DBQ=C:\
Program Files\Microsoft Visual Studio\VB98\BIBLIO.MDB;”
set conn=Server.CreateObject(“ADODB.Connection”)
conn.open connStr
5.4.4 Cơ sở dữ liệu MS SQL Server
connStr=“Provider=SQLOLEDB.1;Persist Security Info=False;
User ID=sa;Initial Catalog=AdvWorks;Data Source=localhost”
set conn=Server.CreateObject(“ADODB.Connection”)
conn.open connStr
Nếu nguồn dữ liệu hỗ trợ OLEDB ta có thể sử dụng ADO thông qua ODBC
theo cách tổng quát:
connStr="Provider=MSDASQL.1;Persist Security Info=False;
Data Source=Test"
set conn=Server.CreateObject(“ADODB.Connection”)
conn.open connStr
Trong đó Test là DataSource thiết lập trong System DNS của ODBC
5.5 Sử dụng đối t-ợng RecordSet
5.5.1 Tạo RecordSet:
set rs=Server.CreateObject(“ADODB.RecordSet”)
Để trích rút dữ liệu từ một hoặc nhiều bảng nào đó trong cơ sở dữ liệu, ta
th-ờng kết hợp đối t-ợng Connection vào câu lệnh SQL Select trong ph-ơng thức
Open của RecordSet:
rs.open SQLCommand, Conn
5.5.2 Duyệt qua các bản ghi và truy xuất các tr-ờng của bản ghi:
Do While not rs.eof
Rs.fields](“field_name”)
rs.movenext : di chuyển con trỏ của RecordSet đến bản ghi kế tiếp
loop
rs.close
http://www.ebook.edu.vn 113
Các cách truy cập hợp lệ và t-ơng đ-ơng:
Rs(“field_name”)
Rs.fields(“field_name”)
Rs.fields(“field_name”).value
Rs(1).value
Rs.fields(1).Value
Nếu muốn duyệt qua tất cả các tr-ờng trong bản ghi cóthể dùng lệnh:
For each Fld in rs.fields
Response.write fld.name + “:” + fld.value + “<br>”
Next
5.5.3 Lọc qua các bản ghi trong RecordSet
Có thể sử dụng mệnh đề Where của câu lệnh Select hoặc có thể sử dụng
thuộc tính Filter của RecordSet để chỉ định điều kiện lọc sau khi đã trích xuất dữ
liệu.
Ví dụ:
sqlStr=”Select * from Products”
rs.open sqlStr,conn
rs.filter= “ productCode=‘” & SpecialCode & “’”
Thuộc tính Filter cho phép sử dụng mệnh đề lọc gần giống với mệnh đề
Where
5.5.4 Phân trang với đối t-ợng RecordSet:
Đối t-ợng RecordSet cung cấp 3 thuộc tính quan trọng sau để sử dụng phân
trang:
PageSize: Kích th-ớc bản ghi trong một trang
PageCount: Tổng số trang RecordSet truy vấn đ-ợc
AbsolutePage: Chỉ định trang hiện hành đang cần đ-ợc đọc
Để RecordSet có khả năng phân trang,cần thiết lập thêm tham số cho
RecordSet tr-ớc khi thực hiện truy vấn:
Rs.CursorLocation=3 ‘ Có thể sử dụng hằng adUseClient
Rs.PageSize=15 ‘ 15 bản ghi trong một trang
Tiết theo mở đối t-ợng RecordSet truy vấn dữ liệu với tuỳ chọn là các hằng
adOpenForwardOnly(0), adLockReadOnly (1) truy cho ph-ơng thức Open nh-sau:
Rs.open sqlStr, Conn, 0,1
Công việc sau cùng là địnhvị trang thông qua thuộctính AbsolutePage. Ta
l-u lại vị trí hiện hành của trang dữ liệu thông qua giá trị chứa trong thẻ <input
hidden>. Giá trị này sẽ đ-ợc chuyển về trình chủ mỗi khi ng-ời dùng kích vào.
Xét ví dụ sau:
<%sqlStr="SELECT * FROM Products "
' page navigate session here ...........
Dim lCurrentPage
Dim lPageCount
lCurrentPage = CLng(Request("page"))
If lCurrentPage < 1 Then
lCurrentPage = 1
End If
rs.CursorLocation = 3
rs.PageSize = 15
rs.Open sqlStr, conn, 0, 1 'Const adOpenForwardOnly=0,
adLockReadOnly = 1
lPageCount = rs.PageCount
If lCurrentPage > lPageCount Then
lCurrentPage = lPageCount
End If
if not rs.eof then
rs.AbsolutePage = lCurrentPage end if
call ShowPageNavigation(lCurrentPage,lPageCount)
Do While rs.AbsolutePage = lCurrentPage And Not rs.Eof
Response.write rs("ProductName")
rs.movenext
loop %>
<form >
<input type=hidden name=page >
</form>
<%
Sub ShowPageNavigation (lCurrentPage,lPageCount)
If lCurrentPage <> 1 AND lCurrentPage <> 0 Then
%>
<A MsoNormal">">Previous
<% Else %>
Previous
<% End If%>
<%If lCurrentPage < lPageCount Then%>
<AMsoNormal">">Next
<% Else %>
Next
<% End If%><BR>
Page <B> <%= lCurrentPage%> </B>
<%= lPageCount%>
<%End Sub %>
<script language=javascript>
function setValue(page){
viewFrm.page.value= page;
viewFrm.submit();
}
</script>
5.6 Hiệu chỉnh các bản ghi
5.6.1 Hiệu chỉnh các bản ghi dựa vào RecordSet:
Thêm mới bản ghi: Để thêm mới vào bảng dữ liệu quản lý bởi ph-ơng thức
RecordSet sử dụng ph-ơng thức AddNew
sqlStr=”Select * From Accounts”
rs.open sqlStr,Conn
‘ Thêm tài khoản mới vào bảng Accounts
rs.Addnew
‘gán giá trị cho bản ghi
with rs
.fields(“username”)= ‘New User’
.fields(“password”)=’***’
end with
‘l-u lại
rs.update
‘Chỉnh sửa nội dung trong bản ghi hiện hành:
sqlStr=”Select * From Accounts”
rs.open sqlStr,Conn
with rs
.fields(“password”)=’newpassword’
end with
‘l-u lại
rs.update
‘Xoá bản ghi hiện hành:
sqlStr=”Select * From Accounts where username= ‘” &mkuser &”’”
rs.open sqlStr,Conn
rs.delete
5.6.2 Hiệu chỉnh các bản ghi bằng câu lệnh SQL với đối t-ợng connection
sqlStr=”delete * from Accounts where username= ‘” &mkuser &”’”
Conn.execute sqlStr
5.7 Sử dụng đối t-ợng Command
5.7.1 Tạo đối t-ợng Command:
set cmdUpdate=Server.CreateObject(“ADODB.Command”)
5.7.2 Sử dụng đối t-ợng Command:
sqlUpdate=“update accounts set password = ‘abc’ where
username=”‘” & username & “’”
http://www.ebook.edu.vn 116
cmdUpdate.ActiveConnection=strConn
cmdUpdate.CommandText=strUpdate
cmdUpdate.CommandType=adcmdText
cmdUpdate.Execute
Đối t-ợng Command cũng đ-ợc dùng để nhận kết quả trả về từ câu lệnh
Select hoặc từ một tên bảng dữ liệu, vídụ để lấy toàn bộ nội dung bảng dữ liệu
Accounts, ta chỉ cần chỉ ra tên bảng và mở RecordSet dựa vào đối t-ợng Command:
cmdTable.ActiveConnection=strConn
cmdTable.CommandText=”Accounts”
cmdTable.CommandType=adCmdTable
rs.open cmdTable
5.8 Bài tập ch-ơng 5
Bài 1: Chọn chủ đề đểthiết kế website
1. Website về dịch vụ việc làm.
2. Website về dịch vụ nhà đất (http://www.nhadat.com).
3. Website báo điện tử (http://vnexpress.net )
4. Website tr-ờng học.
5. Website dịch vụ giải trí nh-ECards, Điện hoa, ...
Bài 2: Xây dựng mô hình ứng dụng bán hàng qua mạng, dựa trên cơ sở dữ
liệu, qua đó vận dụng các đối t-ợng của ADODB để có thể kết nối với cơ sở dự liệu
sao cho có thể thể hiện và cung cấp đ-ợc thông tin cho khách hàng. Chủ yếu giới
thiệu cách thức thiết kế một ứng dụng Web có các chức năng sau:
• Xem thông tin chi tiết của một mặt hàng.
• Lựa chọn hàng, thêm vào,bớt ra khỏi giỏ hàng.
• Tính tiền.
Bài 3: Bài tập tổng hợp, thiết kếmột số Web site theo mẫu:
1. Thiết kế website theo mẫu sau (http://www.flowers.com)
http://www.ebook.edu.vn 117
2. Thiết kế website theo mẫu sau (http://shopping.yahoo.com)
3. Thiết kế website theo mẫu sau (http://www.is-edu.hcmuns.edu.vn)
http://www.ebook.edu.vn 118
4. Thiết kế website theo mẫu sau (http://vnexpress.net)
5. Thiết kế website theo mẫu sau (http://www.codeproject.com)
Tài liệu tham khảo
1. Đỗ mai h-ơng: Xây dựng Web động dựa trên công nghệ ASP
Học viện kỹ thuật quân sự - 2000.
2. nguyễn ph-ơng lan: ASP 3.0/ASP.NET
Nhà xuất bản Lao động xã hội - 2003.
3. phạm phú tài:Javascript
Mediaspace Club ấn hành nội bộ - 2003.
4. nguyễn thị thanh trúc:Giáo trình thiết kế và lập trình Web với
ASP
Đại học quốc gia Tp HCM - 2003.
5. nguyễn hữu tuấn: Giáo trình thiết kế Web
Đại học quốc gia Hà Nội - 2001.
6. Giáo trình xây dựng và quản trị Website
Trung tâm điện toán và truyền số liệu Khu vực I - 2003.
7. Nhóm tác giả ELICOM: Xây dựng Web động với ASP
Nhà xuất bản Thống kê - 2000.
8. MICHAEL CORNING: Working with Active Server Page
Que Corporation - 1997.
9. Learning VBScript
XtraNet Communications INC, - 2000
http://www.ebook.edu.vn 120
Bạn đang đọc truyện trên: Truyen247.Pro