KIẾN THỨC

Check list
Ba trong số các chuyên gia web hàng đầu của Úc, Kevin Yank, Roger Hudson và Russ Weakley tổ chức hội thảo được thiết kế để cung cấp cho bạn những kiến thức và kỹ năng cập nhật nhất về CSS, JavaScript

Format Number với Javascript
Khi lập trình yêu cầu có nhập số liệu cần tính toán, đôi khi bạn cần FormatNumber để phân cách hàng nghìn trong khi nhập liệu. Lúc đó bạn nen dùng hàm trong javascript

Tạo slide quảng cáo chuyên nghiệp bằng javascript
Bài này mình sẽ giới thiêu với các bạn cách tạo slide quảng cáo chuyên nghiệp bằng javascript. Ứng dụng trong việc quang cào và giới thiệu sản phẩm trên website

DANH NGÔN

Bí quyết của sự thành công – nếu có - đó là khả năng tự đặt mình vào địa vị người khác và xem xét sự vật vừa theo quan điểm của họ vừa theo quan điểm của mình

Henry Ford
Trang chủ » Thư viện Tutorial » Học CSS - Javascript

Hạn chế việc sao chép nội dung trên website ( 1198 lượt xem )

thiet ke websiteHạn chế việc sao chép nội dung trên website

Để tăng sự mềm dẻo cho trang web, hiện nay người ta đang cố gắng loại bỏ các table khi thiết kế layout, thay vào đó là sử dụng thẻ DIV và kết hợp với CSS. Bài viết này cung cấp một ví dụ đơn giản giúp chúng ta có thể nhanh chóng dựng một layout mà không tốn quá nhiều thời gian cho việc design.


Ví dụ này trình bày cách thiết kế 1 layout gồm 3 phần: header, body, footer. Trong đó phần body gồm left_bodymain_body.

hmweb

example.html 

01 <head>   
02 <title>hmweb.com.vn</title>   
03 <link rel="stylesheet" href="example.css" mce_href="example.css" type="text/css" />   
04 </head>   
05 <body>   
06 <div id="wrapper">   
07  <div id="header">header</div>   
08       
09  <div id="body">   
10   <div id="body_left">body_left</div>   
11   <div id="body_main">body_main</div>   
12   <div class="vide"></div>   
13  </div>   
14       
15  <div id="footer">footer</div>   
16 </div>   
17 </body>   
18 </html>

example.css

01 * {   
02  margin:0;   
03 }   
04 body {   
05         text-align:center;   
06 }  
07 #wrapper {   
08  margin:auto;   
09  width:800px;   
10 }  
11 #header {   
12  height:100px;   
13  background:#99CC66;   
14 }  
15 #footer {   
16  height:100px;   
17  background:#339933;   
18 }  
19 #body_left {   
20  float:left;   
21  width:100px;   
22  height:600px;   
23  background:#FF9900;   
24 }  
25 #body_main {   
26  float:left;   
27  width:700px;   
28  height:600px;   
29  background:#99CCFF;   
30 }   
31 .vide {   
32  clear:both;   
33 }

Như ta thấy ở trên, file html không có gì đặc biệt, nó chỉ bao gồm cấu trúc các thành phần mà ta cần bố trí, còn bố trí như thế nào thì phụ thuộc hoàn toàn vào file CSS.
Bây giờ, ta sẽ tìm hiểu từng bước cách tạo layout trên:

- Tạo div #wrapper dùng để bao hàm toàn bộ trang web. Ta cần căn giữa div này trong cửa sổ để giúp trang web của chúng ta thích ứng với nhiều loại màn hình và độ phân giải khác nhau. Để làm được điều này, ta dùng margin:auto cho Firefox (vô dụng với IE ) và text-align:center trong body cho IE (vô dụng vơi FF ). Cuối cùng, thuộc tính width quyết định độ rộng trang web.

- Tạo các div: #header, #footer, #body. Không có gì đặc biệt, chúng sẽ lấy hết độ rộng của #wrapper và bố trí liên tiếp nhau từ trên xuống dưới: 

<div id="wrapper">            <div id="header"></div>     <div id="body"></div>     <div id="footer"></div>    </div>

- Bây giờ trong div #body, ta sẽ chia làm 2 cột bằng cách tạo 2 div #body_left#body_main với 2 thuộc tính float (trôi nổi) và width. 2 div này sẽ bố trí liên tiếp nhau từ trái sang phải, nếu #body có đủ độ rộng: 

<div id="wrapper">     <div id="header"></div>     <div id="body">                    <div id="body_left"></div>      <div id="body_main"></div>            </div>     <div id="footer"></div>    </div>

- Vấn đề bắt đầu nảy sinh: #footer biến mất 1 cách đầy bí ẩn . Thực ra nó ko biến đi đâu cả, có điều ta ko nhìn thấy được vì nó đã bị #body_left#body_main che mất. Lý do: #body tuy bao hàm #body_left#body_main, nhưng chiều cao của nó lại không phụ thuộc vào chiều cao của #body_left hay #body_main (do thuộc tính "trôi nổi" của chúng). #footer nằm sát dưới #body, mà #bodyheight 0, cho nên #footer sẽ nằm sát dưới #header, và bị #body_left#body_main che khuất.

Dĩ nhiên ta có thể đặt height cho #body bằng với height của #body_left và #body_main để đẩy #footer xuống đúng chỗ. Tuy nhiên #body_left#body_main thường có height thay đổi (phụ thuộc vào nội dung của chúng), và height của chúng thường cũng không bằng nhau. Cho nên ta chọn giải pháp là đặt thêm 1 div đặc biệt với thuộc tính clear:both bên dưới. Với thuộc tính clear:both, div đặc biệt này sẽ luôn nằm sát dưới 2 div "trôi nổi" kia. #body lại luôn phải bao hàm div đặc biệt này, do đó, nó sẽ luôn có height bằng với height lớn nhất của #body_left #body_main. Nhờ vậy, #footer luôn được định vị đúng chỗ:

<div id="wrapper">     <div id="header"></div>     <div id="body">      <div id="body_left"></div>      <div id="body_main"></div>      <div class="vide"></div>     </div>     <div id="footer"></div>    </div>

OK! Vậy là ta đã dựng xong một layout mềm dẻo, với code html hết sức gọn gàng sáng sủa. Một điều cần lưu ý là khi bố trí các div tạo cột, cần tính với độ rộng bao ngoài của div đó (margin+border+padding+width). Ở ví dụ này, nếu #body_mainpadding:5px thì #wrapper phải rộng ra thêm 10px nữa mới đủ chỗ, nếu không nó sẽ nhảy xuống dưới .

Phuc Thinh Website

Thư viện Template | Website template

Template Food & Drink No.10
Template Food & Drink No.10
Template Education No.8
Template Education No.8
Template Travel No.10
Template Travel No.10
Template Gift No.1
Template Gift No.1
Template Flower No.11
Template Flower No.11
Template Travel No.4
Template Travel No.4
Template Travel No.8
Template Travel No.8
Template Art & Photography  No.6
Template Art & Photography No.6
Template Travel No.1
Template Travel No.1
Template Wedding No.5
Template Wedding No.5
Template Gift No.2
Template Gift No.2
Template Wedding No.2
Template Wedding No.2
«123»
Số lượt truy cập web: 1,353,556 - Trong tháng này: 310,389 - Khách truy cập hôm nay: 99 - Số người đang online: 09.Developed by Phuc Thinh