Floating menu thực sự không phải là một thủ thuật gì mới và ghê gớm lắm đâu. Nó có từ rất lâu rồi và cách dùng nó cũng thực sự không quá khó. Trong bài viết này tôi sẽ hướng dẫn các bạn tạo một floating menu cho website và áp dụng nó vào trong WordPress.


#Tạo hình với HTML & CSS

Trước hết thì mình cần phải xây dựng trước một cấu trúc menu với HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<nav id="fixNav">
  <ul>
    <li><a href="#">Trang chủ</a></li>
    <li><a href="#">Izwebz Store</a></li>
    <li><a href="#">Newbie</a></li>
    <li>
      <a href="#">Video</a>
      <ul class="sub-menu">
        <li><a href="#">Html & CSS</a></li>
        <li><a href="#">PHP & MySQL</a></li>
        <li><a href="#">jQuery</a></li>
     </ul>
    </li>
  </ul>
</nav>
Dựa vào cấu trúc trên thì các bạn có thể thấy, menu được xây dựng có 2 cấp. Bây giờ các bạn hãy tiến hành CSS cho menu, tôi xây dựng menu này có style giống như menu đang dùng trên izwebz.com.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#fixNav{
  width: 100%;
  height: 35px;
  background-color: #0082bb;
  display: block;
  box-shadow: 0px 2px 2px rgba(0,0,0,0.5); /*Đổ bóng cho menu*/
  position: fixed; /*Cho menu cố định 1 vị trí với top và left*/
  top: 0; /*Nằm trên cùng*/
  left: 0; /*Nằm sát bên trái*/
  z-index: 100000; /*Hiển thị lớp trên cùng*/
}
#fixNav ul{
  margin: 0;
  padding: 0;
}
#fixNav ul li{
  list-style:none inside;
  width: auto;
  float: left;
  line-height: 35px; /*Cho text canh giữa menu*/
  color: #fff;
  padding: 0;
  margin-right:10px;
  position: relative;
}
#fixNav ul li a{
  text-transform: uppercase;
  white-space: nowrap; /*Cho chữ trong menu không bị wrap*/
  padding: 0 10px;
  color: #fff;
  display: block;
  font-size: 0.8em;
  text-decoration: none;
}
/*CSS Style cho Submenu*/
#fixNav ul li ul {
  position: absolute;
  width: auto;
  display: none;
  background-color: #252525;
  border-bottom: 3px solid #0082bb;
  padding-left: 5px;
}
#fixNav ul li ul li{
  display: block;
  padding:0;
  margin: 0;
  float: none; /*Bỏ float cho li cấp thứ 2*/
}
/* Hover cho submenu */
#fixNav ul li:hover {
  /* Hover thì li sẽ đổi màu*/
  background-color: #252525;
}
#fixNav ul li:hover ul{
  /*Display ra submenu*/
  display: block;
}
/*Không copy cái này, dùng tăng padding top bottom để demo cuộn*/
p{
  padding-top: 80px;
  padding-bottom: 80px;
}
Giải thích ý nghĩa của css tôi có chú thích comment phía trong code. Các bạn có thể xem và tham khảo. Lưu ý: Các bạn nên tham khảo qua các bài viết hướng dẫn xây dựng menu để có thể hình dung rõ hơn.
Sau khi làm xong menu như trên thì các bạn đã có cho mình một cái floating menu rồi đó. Bây giờ tôi sẽ giải thích rõ hơn. Các bạn hãy quan sát trong css chổ đầu tiên, khai báo cho #fixNav.
1
2
3
4
5
6
7
8
9
10
11
#fixNav{
  width: 100%;
  height: 35px;
  background-color: #0082bb;
  display: block;
  box-shadow: 0px 2px 2px rgba(0,0,0,0.5); /*Đổ bóng cho menu*/
  position: fixed; /*Cho menu cố định 1 vị trí với top và left*/
  top: 0; /*Nằm trên cùng*/
  left: 0; /*Nằm sát bên trái*/
  z-index: 100000; /*Hiển thị lớp trên cùng*/
}
Các bạn có thể quan sát thấy css position có giá trị là fixed. Với bất kỳ đối tượng nào được gán css position có giá trị fixed, thì sẽ được cố định tại một vị trí nhất định. Vị trí đó sẽ phụ thuộc vào giá trị top left bottom right. Trong trường hợp này tôi khai báo top và left đều bằng 0, tức nó sẽ nằm trên cùng, bên trái. Do width:100% nên menu sẽ kéo dài toàn màn hình. Các bạn có thể xem demo và code bên dưới này:

#Tích hợp thêm jQuery

Như các bạn thấy, thì trên izwebz.com. Menu chỉ hiển thị khi bạn cuộn website đến một vị trí nào đó. Bây giờ thì thôi sẽ tiến hành dùng jQuery để thực hiện điều đó. Quy trình hoạt động thì sẽ như vậy: Cuộn chuột đến một móc có giá trị là 150px thì menu sẽ hiển thị ra. Các bạn hãy thêm đoạn code jQuery này vào, ý nghĩa tôi đã có comment phía trong.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
jQuery(document).ready(function($) {   
  //selector đến menu cần làm việc
  var TopFixMenu = $("#fixNav");
  // dùng sự kiện cuộn chuột để bắt thông tin đã cuộn được chiều dài là bao nhiêu.
    $(window).scroll(function(){
    // Nếu cuộn được hơn 150px rồi
        if($(this).scrollTop()>150){
      // Tiến hành show menu ra   
        TopFixMenu.show();
        }else{
      // Ngược lại, nhỏ hơn 150px thì hide menu đi.
            TopFixMenu.hide();
        }}
    )
})
Lưu ý: các bạn cần phải chèn thư viện jquery vào trước khi dùng.
Tuy nhiên, bây giờ menu vẫn chưa hoạt động. Bạn hãy quay lại css và chỉnh sửa khai báo ở đoạn #fixNav với giá trị display:block thành display:none. Nguyên nhân là chúng ta muốn menu nó ẩn từ đầu, chỉ khi cuộn chuột vượt móc giá trị nào đó nó mới hiện ra thôi.

#Tích hợp vào trong WordPress

Công việc của chúng ta là sẽ tiến hành tích hợp nó vào trong WordPress để hiển thị thông tin ra một cách tự động theo quản lý và sắp xếp của người quản trị.
wp menu active
Trước tiên, trong WordPress tôi sẽ dùng wp menus để làm việc. Các bạn có thể vào trong wp-admin>appearance>menus để tạo và sắp xếp menu mới. Trong trường hợp không có mục đó, bạn cần phải vào file functions.php và khai báo như bên dưới này để kích hoạt tính năng wp menus lên.
1
add_theme_support( 'menus' );
Sau khi vảo trong đó thì các bạn có thể tiến hành create new menu và kéo thả các mục cần thiết vào. Nếu bị ẩn các bạn có thể bấm view all. WordPress thiết kế cái menus này phương pháp cách kéo thả, đồng thời có phân cấp nên rất tiện lợi và trực quan.
create new menu
Sau khi tạo menu xong thì chúng ta vào file header.php hoặc index.php trong thư mục theme để khai báo và kéo thông tin từ menu mới tạo ra ngoài.
1
2
3
4
5
6
7
8
<?php
wp_nav_menu( array('menu' => 'cat-menu','container' => 'nav','container_id' => 'fixNav', ));
// menu: tên của menu, trong bài viết tôi đặt tên là cat-menu.
// container: element sẽ chứa ul của menu khi wp xuất ra.
// container_id: id của element, nêu không điền thì nó sẽ xuất ra id mặc định của wp.
// Trong ví dụ tham khảo là thẻ <nav> và id là fixNav
?>
Ngoài ra, các bạn có thể tham khảo thêm video này hướng dẫn về cách sử dụng WordPress Menus.
float menu thumbDemo đang hiển thị trên izwebz.com

#Kết luận

Dùng position:fixed để tạo một đối tượng cố định tại một vị trí nào đó trên website không khó. Quan trọng nhất vẫn là ý tưởng của mình để xây dựng nó là một đối tượng đặc biệt hay là một đối tượng dư thừa. Bạn có thể tham khảo một số demo bên dưới này để tạo cảm hướng cho mình